MediaWiki REL1_33
|
Handles a simple LRU key/value map with a maximum number of entries. More...
Public Member Functions | |
__construct ( $maxKeys) | |
clear ( $keys=null) | |
Clear one or several cache entries, or all cache entries. | |
get ( $key, $maxAge=0.0) | |
Get the value for a key. | |
getAllKeys () | |
getField ( $key, $field, $maxAge=0.0) | |
getMaxSize () | |
Get the maximum number of keys allowed. | |
getWithSetCallback ( $key, callable $callback, $rank=self::RANK_TOP, $maxAge=0.0) | |
Get an item with the given key, producing and setting it if not found. | |
has ( $key, $maxAge=0.0) | |
Check if a key exists. | |
hasField ( $key, $field, $maxAge=0.0) | |
serialize () | |
set ( $key, $value, $rank=self::RANK_TOP) | |
Set a key/value pair. | |
setField ( $key, $field, $value, $initRank=self::RANK_TOP) | |
setMaxSize ( $maxKeys) | |
Resize the maximum number of cache entries, removing older entries as needed. | |
setMockTime (&$time) | |
toArray () | |
unserialize ( $serialized) | |
Static Public Member Functions | |
static | newFromArray (array $values, $maxKeys) |
Public Attributes | |
const | RANK_TOP = 1.0 |
Public Attributes inherited from IExpiringStore | |
const | ATTR_EMULATION = 1 |
const | ATTR_SYNCWRITES = 2 |
const | ERR_NO_RESPONSE = 1 |
const | ERR_NONE = 0 |
const | ERR_UNEXPECTED = 3 |
const | ERR_UNREACHABLE = 2 |
const | QOS_EMULATION_SQL = 1 |
const | QOS_SYNCWRITES_BE = 2 |
const | QOS_SYNCWRITES_NONE = 1 |
const | QOS_SYNCWRITES_QC = 3 |
const | QOS_SYNCWRITES_SS = 4 |
const | QOS_UNKNOWN = INF |
const | TTL_DAY = 86400 |
const | TTL_HOUR = 3600 |
const | TTL_INDEFINITE = 0 |
const | TTL_MINUTE = 60 |
const | TTL_MONTH = 2592000 |
const | TTL_PROC_LONG = 30 |
const | TTL_PROC_SHORT = 3 |
const | TTL_SECOND = 1 |
const | TTL_WEEK = 604800 |
const | TTL_YEAR = 31536000 |
Protected Member Functions | |
getCurrentTime () | |
Private Member Functions | |
getAge ( $key, $field=null) | |
ping ( $key) | |
Push an entry to the top of the cache. | |
Private Attributes | |
array | $cache = [] |
Map of (key => value) | |
float | $epoch |
Default entry timestamp if not specified. | |
int | $maxCacheKeys |
Max number of entries. | |
array | $timestamps = [] |
Map of (key => (UNIX timestamp, (field => UNIX timestamp))) | |
float null | $wallClockOverride |
Handles a simple LRU key/value map with a maximum number of entries.
The last-modification timestamp of entries is internally tracked so that callers can specify the maximum acceptable age of entries in calls to the has() method. As a convenience, the hasField(), getField(), and setField() methods can be used for entries that are field/value maps themselves; such fields will have their own internally tracked last-modification timestamp.
Definition at line 37 of file MapCacheLRU.php.
MapCacheLRU::__construct | ( | $maxKeys | ) |
int | $maxKeys | Maximum number of entries allowed (min 1) |
Exception | When $maxKeys is not an int or not above zero |
Definition at line 62 of file MapCacheLRU.php.
References getCurrentTime().
MapCacheLRU::clear | ( | $keys = null | ) |
Clear one or several cache entries, or all cache entries.
string | array | null | $keys |
Definition at line 277 of file MapCacheLRU.php.
References $keys, array(), as, and cache.
Referenced by Title\clearCaches().
MapCacheLRU::get | ( | $key, | |
$maxAge = 0.0 |
|||
) |
Get the value for a key.
This returns null if the key is not set. If the item is already set, it will be pushed to the top of the cache.
string | $key | |
float | $maxAge | Ignore items older than this many seconds [optional] (since 1.32) |
Definition at line 163 of file MapCacheLRU.php.
References cache, has(), and ping().
Referenced by Title\newFromTextThrow().
|
private |
string | int | $key | |
string | int | null | $field | [optional] |
Definition at line 336 of file MapCacheLRU.php.
References getCurrentTime().
Referenced by has(), and hasField().
MapCacheLRU::getAllKeys | ( | ) |
|
protected |
Definition at line 364 of file MapCacheLRU.php.
Referenced by __construct(), getAge(), set(), setField(), and unserialize().
MapCacheLRU::getField | ( | $key, | |
$field, | |||
$maxAge = 0.0 |
|||
) |
string | int | $key | |
string | int | $field | |
float | $maxAge | Ignore items older than this many seconds [optional] (since 1.32) |
Definition at line 228 of file MapCacheLRU.php.
References cache, and hasField().
MapCacheLRU::getMaxSize | ( | ) |
Get the maximum number of keys allowed.
Definition at line 295 of file MapCacheLRU.php.
MapCacheLRU::getWithSetCallback | ( | $key, | |
callable | $callback, | ||
$rank = self::RANK_TOP , |
|||
$maxAge = 0.0 |
|||
) |
Get an item with the given key, producing and setting it if not found.
If the callback returns false, then nothing is stored.
string | $key | |
callable | $callback | Callback that will produce the value |
float | $rank | Bottom fraction of the list where keys start off [Default: 1.0] |
float | $maxAge | Ignore items older than this many seconds [Default: 0.0] (since 1.32) |
Definition at line 256 of file MapCacheLRU.php.
MapCacheLRU::has | ( | $key, | |
$maxAge = 0.0 |
|||
) |
Check if a key exists.
string | $key | |
float | $maxAge | Ignore items older than this many seconds [optional] (since 1.32) |
Definition at line 141 of file MapCacheLRU.php.
References cache, and getAge().
Referenced by get(), getWithSetCallback(), set(), and setField().
MapCacheLRU::hasField | ( | $key, | |
$field, | |||
$maxAge = 0.0 |
|||
) |
string | int | $key | |
string | int | $field | |
float | $maxAge | Ignore items older than this many seconds [optional] (since 1.32) |
Definition at line 207 of file MapCacheLRU.php.
References $value, and getAge().
Referenced by getField().
|
static |
array | $values | Key/value map in order of increasingly recent access |
int | $maxKeys |
Definition at line 77 of file MapCacheLRU.php.
|
private |
Push an entry to the top of the cache.
string | $key |
Definition at line 325 of file MapCacheLRU.php.
References cache.
Referenced by get(), set(), and setField().
MapCacheLRU::serialize | ( | ) |
Definition at line 346 of file MapCacheLRU.php.
References cache, and serialize().
MapCacheLRU::set | ( | $key, | |
$value, | |||
$rank = self::RANK_TOP |
|||
) |
Set a key/value pair.
This will prune the cache if it gets too large based on LRU. If the item is already set, it will be pushed to the top of the cache.
To reduce evictions due to one-off use of many new keys, $rank can be set to have keys start at the top of a bottom fraction of the list. A value of 3/8 means values start at the top of the bottom 3/8s of the list and are moved to the top of the list when accessed a second time.
string | $key | |
mixed | $value | |
float | $rank | Bottom fraction of the list where keys start off [Default: 1.0] |
Definition at line 109 of file MapCacheLRU.php.
References $value, cache, getCurrentTime(), has(), key, and ping().
Referenced by Title\newFromTextThrow().
MapCacheLRU::setField | ( | $key, | |
$field, | |||
$value, | |||
$initRank = self::RANK_TOP |
|||
) |
string | int | $key | |
string | int | $field | |
mixed | $value | |
float | $initRank |
Definition at line 179 of file MapCacheLRU.php.
References $type, $value, cache, getCurrentTime(), has(), and ping().
MapCacheLRU::setMaxSize | ( | $maxKeys | ) |
Resize the maximum number of cache entries, removing older entries as needed.
int | $maxKeys | Maximum number of entries allowed (min 1) |
Exception | When $maxKeys is not an int or not above zero |
Definition at line 307 of file MapCacheLRU.php.
MapCacheLRU::setMockTime | ( | & | $time | ) |
float | null | &$time | Mock UNIX timestamp for testing |
Definition at line 372 of file MapCacheLRU.php.
References $time.
MapCacheLRU::toArray | ( | ) |
Definition at line 90 of file MapCacheLRU.php.
References $cache.
MapCacheLRU::unserialize | ( | $serialized | ) |
Definition at line 353 of file MapCacheLRU.php.
References $data, $serialized, cache, getCurrentTime(), and unserialize().
|
private |
Map of (key => value)
Definition at line 39 of file MapCacheLRU.php.
|
private |
Default entry timestamp if not specified.
Definition at line 43 of file MapCacheLRU.php.
|
private |
Max number of entries.
Definition at line 46 of file MapCacheLRU.php.
|
private |
Map of (key => (UNIX timestamp, (field => UNIX timestamp)))
Definition at line 41 of file MapCacheLRU.php.
|
private |
Definition at line 49 of file MapCacheLRU.php.
const MapCacheLRU::RANK_TOP = 1.0 |
Definition at line 51 of file MapCacheLRU.php.