MediaWiki
1.28.0
|
Functions to get cache objects. More...
Static Public Member Functions | |
static | clear () |
Clear all the cached instances. More... | |
static | getDefaultKeyspace () |
Get the default keyspace for this wiki. More... | |
static | getInstance ($id) |
Get a cached instance of the specified type of cache object. More... | |
static | getLocalClusterInstance () |
Get the main cluster-local cache object. More... | |
static | getLocalServerInstance ($fallback=CACHE_NONE) |
Factory function for CACHE_ACCEL (referenced from DefaultSettings.php) More... | |
static | getMainStashInstance () |
Get the cache object for the main stash. More... | |
static | getMainWANInstance () |
Get the main WAN cache object. More... | |
static | getWANInstance ($id) |
Get a cached instance of the specified type of WAN cache object. More... | |
static | newAnything ($params) |
Factory function for CACHE_ANYTHING (referenced from DefaultSettings.php) More... | |
static | newFromId ($id) |
Create a new cache object of the specified type. More... | |
static | newFromParams ($params) |
Create a new cache object from parameters. More... | |
static | newWANCacheFromId ($id) |
Create a new cache object of the specified type. More... | |
static | newWANCacheFromParams (array $params) |
Create a new cache object of the specified type. More... | |
Static Public Attributes | |
static BagOStuff[] | $instances = [] |
Map of (id => BagOStuff) More... | |
static WANObjectCache[] | $wanInstances = [] |
Map of (id => WANObjectCache) More... | |
Functions to get cache objects.
The word "cache" has two main dictionary meanings, and both are used in this factory class. They are:
The former should always use strongly consistent stores, so callers don't have to deal with stale reads. The latter may be eventually consistent, but callers can use BagOStuff:READ_LATEST to see the latest available data.
Primary entry points:
All the above cache instances (BagOStuff and WANObjectCache) have their makeKey() method scoped to the current wiki ID. Use makeGlobalKey() to avoid this scoping when using keys that need to be shared amongst wikis.
Definition at line 80 of file ObjectCache.php.
|
static |
Clear all the cached instances.
Definition at line 394 of file ObjectCache.php.
Referenced by MediaWiki\MediaWikiServices\disableStorageBackend(), MediaWikiTestCase\doLightweightServiceReset(), and ForkController\prepareEnvironment().
|
static |
Get the default keyspace for this wiki.
This is either the value of the CachePrefix
configuration variable, or (if the former is unset) the DBname
configuration variable, with DBprefix
(if defined).
Definition at line 149 of file ObjectCache.php.
References global, and wfWikiID().
|
static |
Get a cached instance of the specified type of cache object.
string | $id | A key in $wgObjectCaches. |
Definition at line 92 of file ObjectCache.php.
Referenced by MediaWiki\Session\SessionManager\__construct(), Installer\__construct(), Preprocessor\cacheGetTree(), Preprocessor\cacheSetTree(), and LanguageConverter\loadTables().
|
static |
Get the main cluster-local cache object.
Definition at line 351 of file ObjectCache.php.
References global.
Referenced by MediaWiki\Auth\ThrottlePreAuthenticationProvider\__construct(), MediaWiki\Auth\Throttler\__construct(), Pingback\acquireLock(), MWLBFactory\applyDefaultConfig(), MediaWiki\Auth\AuthManager\autoCreateUser(), ApiStashEdit\checkCache(), MediaWiki\Auth\AuthManager\continueAccountCreation(), WikiPage\doPurge(), ApiStashEdit\execute(), WikiPage\getLastPurgeTimestamp(), FileCacheBase\getMissesRecent(), ApiStashEdit\getStashKey(), FileCacheBase\incrMissesRecent(), ApiStashEdit\parseAndStash(), User\pingLimiter(), JobQueueGroup\push(), JobQueueGroup\queuesHaveJobs(), ResourceLoaderModule\saveFileDependencies(), MediaWiki\Auth\AuthManagerTest\testAutoAccountCreation(), MediaWiki\Auth\AuthManagerTest\testContinueAccountCreation(), GlobalTest\testWfForeignMemcKey(), GlobalTest\testWfGlobalCacheKey(), GlobalTest\testWfMemcKey(), WikiPage\triggerOpportunisticLinksUpdate(), and wfGenerateThumbnail().
|
static |
Factory function for CACHE_ACCEL (referenced from DefaultSettings.php)
This will look for any APC or APCu style server-local cache. A fallback cache can be specified if none is found.
// Direct calls ObjectCache::getLocalServerInstance( $fallbackType ); // From $wgObjectCaches via newFromParams() ObjectCache::getLocalServerInstance( [ 'fallback' => $fallbackType ] );
int | string | array | $fallback | Fallback cache or parameter map with 'fallback' |
InvalidArgumentException |
Definition at line 282 of file ObjectCache.php.
References $cache, $fallback, and CACHE_NONE.
Referenced by FileContentsHasher\__construct(), ResourceLoaderFileModule\compileLessFile(), FileBackendGroup\config(), ResourceLoader\filter(), LockManagerGroup\get(), IcuCollation\getFirstLetterData(), DateFormatter\getInstance(), and TemplateParser\getTemplate().
|
static |
Get the cache object for the main stash.
Stash objects are BagOStuff instances suitable for storing light weight data that is not canonically stored elsewhere (such as RDBMS). Stashes should be configured to propagate changes to all data-centers.
Callers should be prepared for:
Definition at line 387 of file ObjectCache.php.
Referenced by SiteStatsUpdate\adjustPending(), WikiPage\doDeleteArticleReal(), SiteStatsUpdate\getPendingDeltas(), UploadBase\getSessionStatus(), SiteStatsUpdate\removePendingDeltas(), UploadBase\setSessionStatus(), and Article\showMissingArticle().
|
static |
Get the main WAN cache object.
Definition at line 364 of file ObjectCache.php.
Referenced by JobQueueDB\__construct(), MessageBlobStore\__construct(), MessageCache\__construct(), ParserTestRunner\addArticles(), Skin\buildSidebar(), FeedUtils\checkPurge(), LocalRepo\checkRedirect(), User\clearSharedCache(), FormatMetadata\fetchExtendedMetadata(), JobQueueGroup\getCachedConfigVar(), WikiPage\getContentModel(), ForeignDBFile\getDescriptionText(), File\getDescriptionText(), DifferenceEngine\getDiffBody(), DjVuHandler\getDimensionInfo(), ApiHelp\getHelp(), BacklinkCache\getNumLinks(), ForeignAPIRepo\getThumbUrlFromCache(), User\getTouched(), ForeignAPIRepo\httpGetCached(), InfoAction\invalidateCache(), LocalFile\invalidateCache(), LocalRepo\invalidateImageRedirect(), ResourceLoaderWikiModule\invalidateModuleCache(), LinkCache\invalidateTitle(), ChangeTags\listExplicitlyDefinedTags(), ChangeTags\listSoftwareActivatedTags(), ChangeTags\listSoftwareDefinedTags(), ChangesFeed\loadFromCache(), LocalFile\loadFromCache(), User\loadFromCache(), AjaxResponse\loadFromMemcached(), Title\loadRestrictions(), Revision\loadText(), SiteStats\numberingroup(), InfoAction\pageCounts(), BacklinkCache\partition(), ResourceLoaderWikiModule\preloadTitleInfo(), User\purge(), ForeignAPIFile\purgeDescriptionPage(), Article\purgePatrolFooterCache(), ChangeTags\purgeTagCacheAll(), ChangeTags\purgeTagUsageCache(), ForeignAPIFile\purgeThumbnails(), ChangesFeed\saveToCache(), MediaWikiTestCase\setUp(), Article\showPatrolFooter(), AjaxResponse\storeInMemcached(), ChangeTags\tagUsageStatistics(), LinkRendererTest\testGetLinkClasses(), ApiQueryWatchlistRawIntegrationTest\testOwnerAndTokenParams(), User\touch(), and ResourceLoaderModule\validateScriptFile().
|
static |
Get a cached instance of the specified type of WAN cache object.
string | $id | A key in $wgWANObjectCaches. |
Definition at line 107 of file ObjectCache.php.
|
static |
Factory function for CACHE_ANYTHING (referenced from DefaultSettings.php)
CACHE_ANYTHING means that stuff has to be cached, not caching is not an option. If a caching method is configured for any of the main caches ($wgMainCacheType, $wgMessageCacheType, $wgParserCacheType), then CACHE_ANYTHING will effectively be an alias to the configured cache choice for that. If no cache choice is configured (by default $wgMainCacheType is CACHE_NONE), then CACHE_ANYTHING will forward to CACHE_DB.
array | $params |
Definition at line 245 of file ObjectCache.php.
References $wgMessageCacheType, $wgParserCacheType, as, CACHE_ANYTHING, CACHE_DB, CACHE_NONE, and global.
|
static |
Create a new cache object of the specified type.
string | $id | A key in $wgObjectCaches. |
InvalidArgumentException |
Definition at line 122 of file ObjectCache.php.
References $wgObjectCaches, CACHE_NONE, and global.
Referenced by BagOStuffTest\setUp(), and BagOStuffTest\testMakeKey().
|
static |
Create a new cache object from parameters.
array | $params | Must have 'factory' or 'class' property. |
InvalidArgumentException |
Definition at line 171 of file ObjectCache.php.
|
static |
Create a new cache object of the specified type.
string | $id | A key in $wgWANObjectCaches. |
UnexpectedValueException |
Definition at line 302 of file ObjectCache.php.
References $params, $wgObjectCaches, $wgWANObjectCaches, and global.
|
static |
Create a new cache object of the specified type.
array | $params |
UnexpectedValueException |
Definition at line 328 of file ObjectCache.php.
References as.
|
static |
Map of (id => BagOStuff)
Definition at line 82 of file ObjectCache.php.
Referenced by MediaWiki\Session\SessionManagerTest\getManager(), ParserTestRunner\staticSetup(), MediaWiki\Auth\AuthManagerTest\testAutoAccountCreation(), and MediaWiki\Session\SessionManagerTest\testConstructor().
|
static |
Map of (id => WANObjectCache)
Definition at line 84 of file ObjectCache.php.