Moodle PHP Documentation 4.1
Moodle 4.1.11 (Build: 20240610) (c8c84b4af18)
|
The memcached store. More...
Public Member Functions | |
__construct ($name, array $configuration=array()) | |
Constructs the store instance. | |
cache_size_details (int $samplekeys=50) | |
Gets the amount of memory used by this specific cache within the store, if known. | |
cleanup () | |
create_clone (array $details=array()) | |
Creates a clone of this store instance ready to be initialised. | |
delete ($key) | |
Deletes an item from the cache store. | |
delete_many (array $keys) | |
Deletes several keys from the cache in a single action. | |
estimate_stored_size ($key, $value) | |
Estimates the storage size used within this cache if the given value is stored with the given key. | |
get ($key) | |
Retrieves an item from the cache store given its key. | |
get_last_io_bytes () | |
Gets the number of bytes read from or written to cache as a result of the last action. | |
get_many ($keys) | |
Retrieves several items from the cache store in a single transaction. | |
get_warnings () | |
Used to notify of configuration conflicts. | |
initialise (cache_definition $definition) | |
Initialises the cache. | |
instance_created () | |
Performs any necessary operation when the store instance has been created. | |
instance_deleted () | |
Performs any necessary clean up when the store instance is being deleted. | |
is_connection_ready () | |
Confirm whether the connection is ready and usable. | |
is_initialised () | |
Returns true once this instance has been initialised. | |
is_ready () | |
Returns true if this store instance is ready to be used. | |
is_searchable () | |
Returns true if the store instance is searchable. | |
my_name () | |
Returns the name of this instance. | |
purge () | |
Purges the cache deleting all items within it. | |
set ($key, $data) | |
Sets an item in the cache given its key and data value. | |
set_many (array $keyvaluearray) | |
Sets many items in the cache in a single transaction. | |
store_total_size () | |
Gets the amount of memory/storage currently used by this cache store if known. | |
supports_data_guarantee () | |
Returns true if the store instance guarantees data. | |
supports_dereferencing_objects () | |
Returns true if the store automatically dereferences objects. | |
supports_multiple_identifiers () | |
Returns false as this store does not support multiple identifiers. | |
supports_native_ttl () | |
Returns true if the store instance supports native ttl. | |
Static Public Member Functions | |
static | are_requirements_met () |
Returns true if the store requirements are met. | |
static | can_add_instance () |
Returns true if the user can add an instance of the store plugin. | |
static | config_get_configuration_array ($data) |
Given the data from the add instance form this function creates a configuration array. | |
static | config_get_hash_options () |
Gets an array of hash options available during configuration. | |
static | config_get_serialiser_options () |
Gets an array of options to use as the serialiser. | |
static | config_set_edit_form_data (moodleform $editform, array $config) |
Allows the cache store to set its data against the edit form before it is shown to the user. | |
static | get_supported_features (array $configuration=array()) |
Returns the supported features as a combined int. | |
static | get_supported_modes (array $configuration=array()) |
Returns the supported modes as a combined int. | |
static | initialise_test_instance (cache_definition $definition) |
Generates an instance of the cache store that can be used for testing. | |
static | is_supported_mode ($mode) |
Returns true if the given mode is supported by this store. | |
static | ready_to_be_used_for_testing () |
Returns true if this cache store instance is both suitable for testing, and ready for testing. | |
static | unit_test_configuration () |
Generates the appropriate configuration required for unit testing. | |
Public Attributes | |
const | DEREFERENCES_OBJECTS = 16 |
The cache store dereferences objects. | |
const | IO_BYTES_NOT_SUPPORTED = -1 |
Returned from get_last_io_bytes if this cache store doesn't support counting bytes read/sent. | |
const | IS_SEARCHABLE = 8 |
The cache is searchable by key. | |
const | MODE_APPLICATION = 1 |
Application caches. | |
const | MODE_REQUEST = 4 |
Request caches. | |
const | MODE_SESSION = 2 |
Session caches. | |
const | REQUIRED_VERSION = '2.0.0' |
The minimum required version of memcached in order to use this store. | |
const | STATIC_ACCEL = '** static accel. **' |
Static caches. | |
const | SUPPORTS_DATA_GUARANTEE = 2 |
Ensures data remains in the cache once set. | |
const | SUPPORTS_MULTIPLE_IDENTIFIERS = 1 |
Supports multi-part keys. | |
const | SUPPORTS_NATIVE_TTL = 4 |
Supports a native ttl system. | |
Protected Member Functions | |
delete_many_connection (Memcached $connection, array $keys) | |
Deletes several keys from the cache in a single action for a specific connection. | |
Static Protected Member Functions | |
static | get_prefixed_keys (Memcached $connection, $prefix) |
Returns all of the keys in the given connection that belong to this cache store instance. | |
Protected Attributes | |
bool | $candeletemulti = false |
True if Memcached\deleteMulti can be used, false otherwise. | |
bool | $clustered = false |
Set to true when this store is clustered. | |
Memcached | $connection |
The memcached connection. | |
cache_definition | $definition |
The cache definition this store was initialised with. | |
bool | $isinitialised = false |
Set to true when this store instance has been initialised. | |
bool | $isready = false |
True when this instance is ready to be initialised. | |
bool | $isshared = false |
True if the memcached server is shared, false otherwise. | |
store | $name |
The name of the store. | |
array | $options = array() |
The options used when establishing the connection. | |
string | $prefix = '' |
The prefix to use on all keys. | |
array | $servers = array() |
An array of servers to use during connection. | |
array | $setconnections = array() |
The an array of memcache connections for the set servers, once established. | |
array | $setservers = array() |
Array of servers to set when in clustered mode. | |
The memcached store.
(Not to be confused with the memcache store)
Configuration options: servers: string: host:port:weight , ... compression: true, false serialiser: SERIALIZER_PHP, SERIALIZER_JSON, SERIALIZER_IGBINARY prefix: string: defaults to instance name hashmethod: HASH_DEFAULT, HASH_MD5, HASH_CRC, HASH_FNV1_64, HASH_FNV1A_64, HASH_FNV1_32, HASH_FNV1A_32, HASH_HSIEH, HASH_MURMUR bufferwrites: true, false
cachestore_memcached::__construct | ( | $name, | |
array | $configuration = array() ) |
Constructs the store instance.
Noting that this function is not an initialisation. It is used to prepare the store for use. The store will be initialised when required and will be provided with a cache_definition at that time.
string | $name | |
array | $configuration |
Reimplemented from cache_store.
|
static |
Returns true if the store requirements are met.
bool |
Implements cache_store_interface.
|
inherited |
Gets the amount of memory used by this specific cache within the store, if known.
This function may be slow and should not be called in normal usage, only for administration pages. The value is usually an estimate, and may not be available at all.
When estimating, a number of sample items will be used for the estimate. If set to 50 (default), then this function will retrieve 50 random items and use that to estimate the total size.
The return value has the following fields:
int | $samplekeys | Number of samples to use |
stdClass | Object with information about the store size |
Reimplemented in cachestore_file.
|
staticinherited |
Returns true if the user can add an instance of the store plugin.
bool |
Reimplemented in cachestore_dummy, cachestore_session, and cachestore_static.
|
inherited |
|
static |
Given the data from the add instance form this function creates a configuration array.
stdClass | $data |
array |
Implements cache_is_configurable.
|
static |
Gets an array of hash options available during configuration.
array |
|
static |
Gets an array of options to use as the serialiser.
array |
|
static |
Allows the cache store to set its data against the edit form before it is shown to the user.
moodleform | $editform | |
array | $config |
Implements cache_is_configurable.
|
inherited |
Creates a clone of this store instance ready to be initialised.
This method is used so that a cache store needs only be constructed once. Future requests for an instance of the store will be given a cloned instance.
If you are writing a cache store that isn't compatible with the clone operation you can override this method to handle any situations you want before cloning.
array | $details | An array containing the details of the store from the cache config. |
cache_store |
cachestore_memcached::delete | ( | $key | ) |
Deletes an item from the cache store.
string | $key | The key to delete. |
bool | Returns true if the operation was a success, false otherwise. |
Reimplemented from cache_store.
cachestore_memcached::delete_many | ( | array | $keys | ) |
Deletes several keys from the cache in a single action.
array | $keys | The keys to delete |
int | The number of items successfully deleted. |
Reimplemented from cache_store.
|
protected |
Deletes several keys from the cache in a single action for a specific connection.
Memcached | $connection | The connection to work on. |
array | $keys | The keys to delete |
int | The number of items successfully deleted. |
|
inherited |
Estimates the storage size used within this cache if the given value is stored with the given key.
This function is not exactly accurate; it does not necessarily take into account all the overheads involved. It is only intended to give a good idea of the relative size of different caches.
The default implementation serializes both key and value and sums the lengths (as a rough estimate which is probably good enough for everything unless the cache offers compression).
mixed | $key | Key |
mixed | $value | Value |
int | Size in bytes |
Reimplemented in cachestore_redis.
cachestore_memcached::get | ( | $key | ) |
Retrieves an item from the cache store given its key.
string | $key | The key to retrieve |
mixed | The data that was associated with the key, or false if the key did not exist. |
Reimplemented from cache_store.
|
inherited |
Gets the number of bytes read from or written to cache as a result of the last action.
This includes calls to the functions get(), get_many(), set(), and set_many(). The number is reset by calling any of these functions.
This should be the actual number of bytes of the value read from or written to cache, giving an impression of the network or other load. It will not be exactly the same amount as netowrk traffic because of protocol overhead, key text, etc.
If not supported, returns IO_BYTES_NOT_SUPPORTED.
int | Bytes read (or 0 if none/not supported) |
Reimplemented in cachestore_file, and cachestore_redis.
cachestore_memcached::get_many | ( | $keys | ) |
Retrieves several items from the cache store in a single transaction.
If not all of the items are available in the cache then the data value for those that are missing will be set to false.
array | $keys | The array of keys to retrieve |
array | An array of items from the cache. There will be an item for each key, those that were not in the store will be set to false. |
Reimplemented from cache_store.
|
staticprotected |
Returns all of the keys in the given connection that belong to this cache store instance.
Requires php memcached extension version 2.0.0 or greater.
Memcached | $connection | |
string | $prefix |
array |
|
static |
Returns the supported features as a combined int.
array | $configuration |
int |
Implements cache_store_interface.
|
static |
Returns the supported modes as a combined int.
array | $configuration |
int |
Implements cache_store_interface.
cachestore_memcached::get_warnings | ( | ) |
Used to notify of configuration conflicts.
The warnings returned here will be displayed on the cache configuration screen.
string[] | Returns an array of warnings (strings) |
Reimplemented from cache_store.
cachestore_memcached::initialise | ( | cache_definition | $definition | ) |
Initialises the cache.
Once this has been done the cache is all set to be used.
coding_exception | if the instance has already been initialised. |
cache_definition | $definition |
Reimplemented from cache_store.
|
static |
Generates an instance of the cache store that can be used for testing.
cache_definition | $definition |
cachestore_memcached|false |
Implements cache_store_interface.
|
inherited |
Performs any necessary operation when the store instance has been created.
Reimplemented in cachestore_file.
cachestore_memcached::instance_deleted | ( | ) |
Performs any necessary clean up when the store instance is being deleted.
Reimplemented from cache_store.
cachestore_memcached::is_connection_ready | ( | ) |
Confirm whether the connection is ready and usable.
boolean |
cachestore_memcached::is_initialised | ( | ) |
Returns true once this instance has been initialised.
bool |
Reimplemented from cache_store.
cachestore_memcached::is_ready | ( | ) |
Returns true if this store instance is ready to be used.
bool |
Reimplemented from cache_store.
|
inherited |
Returns true if the store instance is searchable.
bool |
|
static |
Returns true if the given mode is supported by this store.
int | $mode | One of cache_store\MODE_* |
bool |
Implements cache_store_interface.
cachestore_memcached::my_name | ( | ) |
cachestore_memcached::purge | ( | ) |
Purges the cache deleting all items within it.
boolean | True on success. False otherwise. |
Reimplemented from cache_store.
|
static |
Returns true if this cache store instance is both suitable for testing, and ready for testing.
Cache stores that support being used as the default store for unit and acceptance testing should override this function and return true if there requirements have been met.
bool |
Reimplemented from cache_store.
cachestore_memcached::set | ( | $key, | |
$data ) |
Sets an item in the cache given its key and data value.
string | $key | The key to use. |
mixed | $data | The data to set. |
bool | True if the operation was a success false otherwise. |
Reimplemented from cache_store.
cachestore_memcached::set_many | ( | array | $keyvaluearray | ) |
Sets many items in the cache in a single transaction.
array | $keyvaluearray | An array of key value pairs. Each item in the array will be an associative array with two keys, 'key' and 'value'. |
int | The number of items successfully set. It is up to the developer to check this matches the number of items sent ... if they care that is. |
Reimplemented from cache_store.
|
inherited |
Gets the amount of memory/storage currently used by this cache store if known.
This value should be obtained quickly from the store itself, if available.
This is the total memory usage of the entire store, not for ther specific cache in question.
Where not supported (default), will always return null.
int|null | Amount of memory used in bytes or null |
Reimplemented in cachestore_file, and cachestore_redis.
|
inherited |
Returns true if the store instance guarantees data.
bool |
|
inherited |
Returns true if the store automatically dereferences objects.
bool |
cachestore_memcached::supports_multiple_identifiers | ( | ) |
Returns false as this store does not support multiple identifiers.
(This optional function is a performance optimisation; it must be consistent with the value from get_supported_features.)
bool | False |
Reimplemented from cache_store.
|
inherited |
Returns true if the store instance supports native ttl.
bool |
|
static |
Generates the appropriate configuration required for unit testing.
array | Array of unit test configuration data to be used by initialise(). |
Implements cache_store_interface.
|
protected |
True if Memcached\deleteMulti can be used, false otherwise.
This required extension version 2.0.0 or greater.
|
protected |
True if the memcached server is shared, false otherwise.
This required extension version 2.0.0 or greater.
|
inherited |
The cache store dereferences objects.
When set, loaders will assume that all data coming from this store has already had all references resolved. So even for complex object structures it will not try to remove references again.
|
inherited |
Application caches.
These are shared caches.
|
inherited |
Request caches.
Static caches really.
|
inherited |
Session caches.
Just access to the PHP session.