MediaWiki master
|
Class for dealing with PoolCounters using class members. More...
Inherited by MediaWiki\PoolCounter\PoolCounterWorkViaCallback, and MediaWiki\PoolCounter\PoolWorkArticleView.
Public Member Functions | |
__construct (string $type, string $key, ?PoolCounter $poolCounter=null) | |
doWork () | |
Actually perform the work, caching it if needed. | |
error ( $status) | |
Do something with the error, like showing it to the user. | |
execute ( $skipcache=false) | |
Get the result of the work (whatever it is), or the result of the error() function. | |
fallback ( $fast) | |
A work not so good (eg. | |
getCachedWork () | |
Retrieve the work from cache. | |
logError ( $status) | |
Log an error. | |
Protected Member Functions | |
isFastStaleEnabled () | |
Should fast stale mode be used? | |
Protected Attributes | |
bool | $cacheable = false |
string | $type = 'generic' |
Class for dealing with PoolCounters using class members.
Definition at line 29 of file PoolCounterWork.php.
MediaWiki\PoolCounter\PoolCounterWork::__construct | ( | string | $type, |
string | $key, | ||
?PoolCounter | $poolCounter = null ) |
string | $type | The class of actions to limit concurrency for (task type) |
string | $key | Key that identifies the queue this work is placed on |
PoolCounter | null | $poolCounter |
Definition at line 42 of file PoolCounterWork.php.
References MediaWiki\PoolCounter\PoolCounterWork\$type, and MediaWiki\MediaWikiServices\getInstance().
|
abstract |
Actually perform the work, caching it if needed.
Reimplemented in MediaWiki\PoolCounter\PoolCounterWorkViaCallback, MediaWiki\PoolCounter\PoolWorkArticleView, MediaWiki\PoolCounter\PoolWorkArticleViewCurrent, and MediaWiki\PoolCounter\PoolWorkArticleViewOld.
Referenced by MediaWiki\PoolCounter\PoolCounterWork\execute().
MediaWiki\PoolCounter\PoolCounterWork::error | ( | $status | ) |
Do something with the error, like showing it to the user.
Status | $status |
Reimplemented in MediaWiki\PoolCounter\PoolCounterWorkViaCallback, and MediaWiki\PoolCounter\PoolWorkArticleView.
Definition at line 82 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolCounterWork\execute().
MediaWiki\PoolCounter\PoolCounterWork::execute | ( | $skipcache = false | ) |
Get the result of the work (whatever it is), or the result of the error() function.
This returns the result of the one of the following methods:
If these all return false, then the result of error() is returned.
In slow-stale mode, these three methods are called in the sequence given above, and the first non-false response is used. This means in case of concurrent cache-miss requests for the same revision, later ones will load on DBs and other backend services, and wait for earlier requests to succeed and then read out their saved result.
In fast-stale mode, if other requests hold doWork lock already, we call fallback() first to let it try to find an acceptable return value. If fallback() returns false, then we will wait for the doWork lock, as for slow stale mode, including potentially calling fallback() a second time.
bool | $skipcache |
Definition at line 137 of file PoolCounterWork.php.
References MediaWiki\PoolCounter\PoolCounter\DONE, MediaWiki\PoolCounter\PoolCounterWork\doWork(), MediaWiki\PoolCounter\PoolCounter\ERROR, MediaWiki\PoolCounter\PoolCounterWork\error(), MediaWiki\PoolCounter\PoolCounterWork\execute(), MediaWiki\PoolCounter\PoolCounterWork\fallback(), MediaWiki\PoolCounter\PoolCounterWork\getCachedWork(), MediaWiki\PoolCounter\PoolCounterWork\isFastStaleEnabled(), MediaWiki\PoolCounter\PoolCounter\LOCK_HELD, MediaWiki\PoolCounter\PoolCounter\LOCKED, MediaWiki\PoolCounter\PoolCounterWork\logError(), MediaWiki\PoolCounter\PoolCounter\QUEUE_FULL, and MediaWiki\PoolCounter\PoolCounter\TIMEOUT.
Referenced by DjVuHandler\doTransform(), MediaWiki\SpecialPage\ContributionsSpecialPage\execute(), MediaWiki\PoolCounter\PoolCounterWork\execute(), MediaWiki\FileRepo\ThumbnailEntryPoint\generateThumbnail(), and File\getThumbnailSource().
MediaWiki\PoolCounter\PoolCounterWork::fallback | ( | $fast | ) |
A work not so good (eg.
expired one) but better than an error message.
bool | $fast | True if PoolCounter is requesting a fast stale response (pre-wait) |
Reimplemented in MediaWiki\PoolCounter\PoolCounterWorkViaCallback, and MediaWiki\PoolCounter\PoolWorkArticleViewCurrent.
Definition at line 72 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolCounterWork\execute().
MediaWiki\PoolCounter\PoolCounterWork::getCachedWork | ( | ) |
Retrieve the work from cache.
Reimplemented in MediaWiki\PoolCounter\PoolCounterWorkViaCallback, MediaWiki\PoolCounter\PoolWorkArticleViewCurrent, and MediaWiki\PoolCounter\PoolWorkArticleViewOld.
Definition at line 61 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolCounterWork\execute().
|
protected |
Should fast stale mode be used?
Definition at line 91 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolCounterWork\execute().
MediaWiki\PoolCounter\PoolCounterWork::logError | ( | $status | ) |
Log an error.
Status | $status |
Definition at line 101 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolCounterWork\execute().
|
protected |
Definition at line 33 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolWorkArticleViewCurrent\__construct().
|
protected |
Definition at line 31 of file PoolCounterWork.php.
Referenced by MediaWiki\PoolCounter\PoolCounterWorkViaCallback\__construct(), and MediaWiki\PoolCounter\PoolCounterWork\__construct().