MediaWiki REL1_35
|
A wrapper class for the PECL memcached client. More...
Public Member Functions | |
__construct ( $params) | |
Available parameters are: | |
decr ( $key, $value=1, $flags=0) | |
Decrease stored value of $key by $value while preserving its TTL. | |
incr ( $key, $value=1, $flags=0) | |
Increase stored value of $key by $value while preserving its TTL. | |
setNewPreparedValues (array $valueByKey) | |
Prepare values for storage and get their serialized sizes, or, estimate those sizes. | |
Public Member Functions inherited from MemcachedBagOStuff | |
__construct (array $params) | |
makeKeyInternal ( $keyspace, $args) | |
Construct a cache key. | |
validateKeyEncoding ( $key) | |
Ensure that a key is safe to use (contains no control characters and no characters above the ASCII range.) | |
Public Member Functions inherited from MediumSpecificBagOStuff | |
add ( $key, $value, $exptime=0, $flags=0) | |
Insert an item if it does not already exist. | |
addBusyCallback (callable $workCallback) | |
Let a callback be run to avoid wasting time on special blocking calls. | |
changeTTL ( $key, $exptime=0, $flags=0) | |
Change the expiration on a key if it exists. | |
changeTTLMulti (array $keys, $exptime, $flags=0) | |
Change the expiration of multiple keys that exist. | |
clearLastError () | |
Clear the "last error" registry. | |
delete ( $key, $flags=0) | |
Delete an item. | |
deleteMulti (array $keys, $flags=0) | |
Batch deletion. | |
deleteObjectsExpiringBefore ( $timestamp, callable $progress=null, $limit=INF) | |
Delete all objects expiring before a certain date. | |
get ( $key, $flags=0) | |
Get an item with the given key. | |
getLastError () | |
Get the "last error" registered; clearLastError() should be called manually. | |
getMulti (array $keys, $flags=0) | |
Get an associative array containing the item for each of the keys that have items. | |
getQoS ( $flag) | |
getSegmentationSize () | |
getSegmentedValueMaxSize () | |
incrWithInit ( $key, $exptime, $value=1, $init=null, $flags=0) | |
Increase the value of the given key (no TTL change) if it exists or create it otherwise. | |
lock ( $key, $timeout=6, $expiry=6, $rclass='') | |
Acquire an advisory lock on a key string. | |
makeGlobalKey ( $class,... $components) | |
Make a global cache key. | |
makeKey ( $class,... $components) | |
Make a cache key, scoped to this instance's keyspace. | |
merge ( $key, callable $callback, $exptime=0, $attempts=10, $flags=0) | |
Merge changes into the existing cache value (possibly creating a new one) | |
set ( $key, $value, $exptime=0, $flags=0) | |
Set an item. | |
setMulti (array $data, $exptime=0, $flags=0) | |
Batch insertion/replace. | |
unlock ( $key) | |
Release an advisory lock on a key string. | |
Public Member Functions inherited from BagOStuff | |
getCurrentTime () | |
getLogger () | |
getScopedLock ( $key, $timeout=6, $expiry=30, $rclass='') | |
Get a lightweight exclusive self-unlocking lock. | |
getWithSetCallback ( $key, $exptime, $callback, $flags=0) | |
Get an item with the given key, regenerating and setting it if not found. | |
setDebug ( $enabled) | |
setLogger (LoggerInterface $logger) | |
setMockTime (&$time) | |
Protected Member Functions | |
checkResult ( $key, $result) | |
Check the return value from a client method call and take any necessary action. | |
doAdd ( $key, $value, $exptime=0, $flags=0) | |
Insert an item if it does not already exist. | |
doCas ( $casToken, $key, $value, $exptime=0, $flags=0) | |
Check and set an item. | |
doChangeTTL ( $key, $exptime, $flags) | |
doDelete ( $key, $flags=0) | |
Delete an item. | |
doDeleteMulti (array $keys, $flags=0) | |
doGet ( $key, $flags=0, &$casToken=null) | |
doGetMulti (array $keys, $flags=0) | |
Get an associative array containing the item for each of the keys that have items. | |
doSet ( $key, $value, $exptime=0, $flags=0) | |
Set an item. | |
doSetMulti (array $data, $exptime=0, $flags=0) | |
serialize ( $value) | |
unserialize ( $value) | |
Protected Member Functions inherited from MemcachedBagOStuff | |
fixExpiry ( $exptime) | |
Protected Member Functions inherited from MediumSpecificBagOStuff | |
cas ( $casToken, $key, $value, $exptime=0, $flags=0) | |
Check and set an item. | |
debug ( $text) | |
getExpirationAsTimestamp ( $exptime) | |
Convert an optionally relative timestamp to an absolute time. | |
getExpirationAsTTL ( $exptime) | |
Convert an optionally absolute expiry time to a relative time. | |
getSerialized ( $value, $key) | |
Get the serialized form a value, using any applicable prepared value. | |
guessSerialValueSize ( $value, $depth=0, &$loops=0) | |
Estimate the size of a variable once serialized. | |
isInteger ( $value) | |
Check if a value is an integer. | |
isRelativeExpiration ( $exptime) | |
makeValueOrSegmentList ( $key, $value, $exptime, $flags) | |
Determine the entry (inline or segment list) to store under a key to save the value. | |
mergeViaCas ( $key, callable $callback, $exptime, $attempts, $flags) | |
resolveSegments ( $key, $mainValue) | |
Get and reassemble the chunks of blob at the given key. | |
setLastError ( $err) | |
Set the "last error" registry. | |
Protected Member Functions inherited from BagOStuff | |
fieldHasFlags ( $field, $flags) | |
mergeFlagMaps (array $bags) | |
Merge the flag maps of one or more BagOStuff objects into a "lowest common denominator" map. | |
Protected Attributes | |
Memcached null | $asyncClient |
bool | $hasUnflushedChanges = false |
Whether the non-buffering client should be flushed before use. | |
Memcached | $syncClient |
bool | $syncClientIsBuffering = false |
Whether the non-buffering client is locked from use. | |
Protected Attributes inherited from MediumSpecificBagOStuff | |
callable[] | $busyCallbacks = [] |
string | $keyspace = 'local' |
int | $lastError = self::ERR_NONE |
ERR_* class constant. | |
array[] | $locks = [] |
Lock tracking. | |
array[] | $preparedValues = [] |
Map of (key => (PHP variable value, serialized value)) | |
int | $segmentationSize |
Bytes; chunk size of segmented cache values. | |
int | $segmentedValueMaxSize |
Bytes; maximum total size of a segmented cache value. | |
int | $syncTimeout |
Seconds. | |
Protected Attributes inherited from BagOStuff | |
callable null | $asyncHandler |
int[] | $attrMap = [] |
Map of (ATTR_* class constant => QOS_* class constant) | |
bool | $debugMode = false |
LoggerInterface | $logger |
Private Member Functions | |
acquireAsyncClient () | |
acquireSyncClient () | |
initializeClient (Memcached $client, array $params, array $options) | |
Initialize the client only if needed and reuse it otherwise. | |
releaseAsyncClient ( $client) | |
Static Private Attributes | |
static array | $OPTS_ASYNC_WRITES |
Memcached options. | |
static array | $OPTS_SYNC_WRITES |
Memcached options. | |
Additional Inherited Members | |
Public Attributes inherited from BagOStuff | |
const | READ_LATEST = 1 |
Bitfield constants for get()/getMulti(); these are only advisory. | |
const | READ_VERIFIED = 2 |
const | WRITE_ALLOW_SEGMENTS = 16 |
const | WRITE_BACKGROUND = 64 |
const | WRITE_CACHE_ONLY = 8 |
const | WRITE_PRUNE_SEGMENTS = 32 |
const | WRITE_SYNC = 4 |
Bitfield constants for set()/merge(); these are only advisory. | |
A wrapper class for the PECL memcached client.
Definition at line 29 of file MemcachedPeclBagOStuff.php.
MemcachedPeclBagOStuff::__construct | ( | $params | ) |
Available parameters are:
array | $params |
Definition at line 67 of file MemcachedPeclBagOStuff.php.
References $asyncClient, $syncClient, initializeClient(), serialize(), and true.
|
private |
Definition at line 446 of file MemcachedPeclBagOStuff.php.
References $asyncClient, and $syncClient.
Referenced by doDeleteMulti(), and doSetMulti().
|
private |
Definition at line 426 of file MemcachedPeclBagOStuff.php.
References $syncClient.
Referenced by decr(), doAdd(), doCas(), doChangeTTL(), doDelete(), doDeleteMulti(), doGet(), doGetMulti(), doSet(), doSetMulti(), and incr().
|
protected |
Check the return value from a client method call and take any necessary action.
Returns the value that the wrapper function should return. At present, the return value is always the same as the return value from the client, but some day we might find a case where it should be different.
string | $key | The key used by the caller, or false if there wasn't one. |
mixed | $result | The return value |
Definition at line 291 of file MemcachedPeclBagOStuff.php.
References $syncClient, MediumSpecificBagOStuff\debug(), and MediumSpecificBagOStuff\setLastError().
Referenced by decr(), doAdd(), doCas(), doChangeTTL(), doDelete(), doDeleteMulti(), doGet(), doGetMulti(), doSet(), doSetMulti(), and incr().
MemcachedPeclBagOStuff::decr | ( | $key, | |
$value = 1 , |
|||
$flags = 0 |
|||
) |
Decrease stored value of $key by $value while preserving its TTL.
string | $key | |
int | $value | Value to subtract from $key (default: 1) [optional] |
int | $flags | Bit field of class WRITE_* constants [optional] |
Reimplemented from BagOStuff.
Definition at line 262 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), and MediumSpecificBagOStuff\debug().
|
protected |
Insert an item if it does not already exist.
string | $key | |
mixed | $value | |
int | $exptime | |
int | $flags | Bitfield of BagOStuff::WRITE_* constants (since 1.33) |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 242 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), MemcachedBagOStuff\fixExpiry(), and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
Check and set an item.
mixed | $casToken | |
string | $key | |
mixed | $value | |
int | $exptime | Either an interval in seconds or a unix timestamp for expiry |
int | $flags | Bitfield of BagOStuff::WRITE_* constants |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 218 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), MemcachedBagOStuff\fixExpiry(), and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
string | $key | |
int | $exptime | |
int | $flags |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 385 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), and MemcachedBagOStuff\fixExpiry().
|
protected |
Delete an item.
string | $key | |
int | $flags | Bitfield of BagOStuff::WRITE_* constants |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 230 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), true, and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
string[] | $keys | List of keys |
int | $flags | Bitfield of BagOStuff::WRITE_* constants |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 357 of file MemcachedPeclBagOStuff.php.
References $keys, acquireAsyncClient(), acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), BagOStuff\fieldHasFlags(), releaseAsyncClient(), and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
string | $key | |
int | $flags | Bitfield of BagOStuff::READ_* constants [optional] |
mixed | null | &$casToken | Token to use for check-and-set comparisons |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 180 of file MemcachedPeclBagOStuff.php.
References $res, acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
Get an associative array containing the item for each of the keys that have items.
string[] | $keys | List of keys |
int | $flags | Bitfield; supports READ_LATEST [optional] |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 323 of file MemcachedPeclBagOStuff.php.
References $keys, acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
Set an item.
string | $key | |
mixed | $value | |
int | $exptime | Either an interval in seconds or a unix timestamp for expiry |
int | $flags | Bitfield of BagOStuff::WRITE_* constants |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 202 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), MemcachedBagOStuff\fixExpiry(), true, and MemcachedBagOStuff\validateKeyEncoding().
|
protected |
mixed[] | $data | Map of (key => value) |
int | $exptime | Either an interval in seconds or a unix timestamp for expiry |
int | $flags | Bitfield of BagOStuff::WRITE_* constants |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 336 of file MemcachedPeclBagOStuff.php.
References acquireAsyncClient(), acquireSyncClient(), checkResult(), MediumSpecificBagOStuff\debug(), BagOStuff\fieldHasFlags(), MemcachedBagOStuff\fixExpiry(), releaseAsyncClient(), and MemcachedBagOStuff\validateKeyEncoding().
MemcachedPeclBagOStuff::incr | ( | $key, | |
$value = 1 , |
|||
$flags = 0 |
|||
) |
Increase stored value of $key by $value while preserving its TTL.
string | $key | Key to increase |
int | $value | Value to add to $key (default: 1) [optional] |
int | $flags | Bit field of class WRITE_* constants [optional] |
Reimplemented from BagOStuff.
Definition at line 254 of file MemcachedPeclBagOStuff.php.
References acquireSyncClient(), checkResult(), and MediumSpecificBagOStuff\debug().
|
private |
Initialize the client only if needed and reuse it otherwise.
This avoids duplicate servers in the list and new connections.
Memcached | $client | |
array | $params | |
array | $options | Base options for Memcached::setOptions() |
RuntimeException |
Definition at line 115 of file MemcachedPeclBagOStuff.php.
References true.
Referenced by __construct().
|
private |
Memcached | $client |
Definition at line 461 of file MemcachedPeclBagOStuff.php.
Referenced by doDeleteMulti(), and doSetMulti().
|
protected |
mixed | $value |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 393 of file MemcachedPeclBagOStuff.php.
References serialize().
MemcachedPeclBagOStuff::setNewPreparedValues | ( | array | $valueByKey | ) |
Prepare values for storage and get their serialized sizes, or, estimate those sizes.
All previously prepared values will be cleared. Each of the new prepared values will be individually cleared as they get used by write operations for that key. This is done to avoid unchecked growth in PHP memory usage.
Example usage:
This is only useful if the caller needs an estimate of the serialized object sizes. The caller cannot know the serialization format and even if it did, it could be expensive to serialize complex values twice just to get the size information before writing them to cache. This method solves both problems by making the cache instance do the serialization and having it reuse the result when the cache write happens.
array | $valueByKey | Map of (cache key => PHP variable value to serialize) |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 270 of file MemcachedPeclBagOStuff.php.
References MediumSpecificBagOStuff\guessSerialValueSize().
|
protected |
string | int | $value |
Reimplemented from MediumSpecificBagOStuff.
Definition at line 408 of file MemcachedPeclBagOStuff.php.
References MediumSpecificBagOStuff\isInteger(), and unserialize().
Referenced by unserialize().
|
protected |
Definition at line 33 of file MemcachedPeclBagOStuff.php.
Referenced by __construct(), and acquireAsyncClient().
|
protected |
Whether the non-buffering client should be flushed before use.
Definition at line 38 of file MemcachedPeclBagOStuff.php.
|
staticprivate |
Memcached options.
Definition at line 46 of file MemcachedPeclBagOStuff.php.
|
staticprivate |
Memcached options.
Definition at line 41 of file MemcachedPeclBagOStuff.php.
|
protected |
Definition at line 31 of file MemcachedPeclBagOStuff.php.
Referenced by __construct(), acquireAsyncClient(), acquireSyncClient(), and checkResult().
|
protected |
Whether the non-buffering client is locked from use.
Definition at line 36 of file MemcachedPeclBagOStuff.php.