MediaWiki  master
FSLockManager Class Reference

Simple version of LockManager based on using FS lock files. More...

Inheritance diagram for FSLockManager:
Collaboration diagram for FSLockManager:

Public Member Functions

 __construct (array $config)
 Construct a new instance from configuration. More...
 
 __destruct ()
 Make sure remaining locks get cleared for sanity. More...
 
- Public Member Functions inherited from LockManager
 __construct (array $config)
 Construct a new instance from configuration. More...
 
 lock (array $paths, $type=self::LOCK_EX, $timeout=0)
 Lock the resources at the given abstract paths. More...
 
 lockByType (array $pathsByType, $timeout=0)
 Lock the resources at the given abstract paths. More...
 
 unlock (array $paths, $type=self::LOCK_EX)
 Unlock the resources at the given abstract paths. More...
 
 unlockByType (array $pathsByType)
 Unlock the resources at the given abstract paths. More...
 

Protected Member Functions

 doLock (array $paths, $type)
 
 doSingleLock ($path, $type)
 Lock a single resource key. More...
 
 doSingleUnlock ($path, $type)
 Unlock a single resource key. More...
 
 doUnlock (array $paths, $type)
 
 getLockPath ($path)
 Get the path to the lock file for a key. More...
 
- Protected Member Functions inherited from LockManager
 doLock (array $paths, $type)
 Lock resources with the given keys and lock type. More...
 
 doLockByType (array $pathsByType)
 
 doUnlock (array $paths, $type)
 Unlock resources with the given keys and lock type. More...
 
 doUnlockByType (array $pathsByType)
 
 normalizePathsByType (array $pathsByType)
 Normalize the $paths array by converting LOCK_UW locks into the appropriate type and removing any duplicated paths for each lock type. More...
 
 sha1Base16Absolute ($path)
 Get the base 16 SHA-1 of a string, padded to 31 digits. More...
 
 sha1Base36Absolute ($path)
 Get the base 36 SHA-1 of a string, padded to 31 digits. More...
 

Protected Attributes

array $handles = []
 Map of (locked key => lock file handle) More...
 
 $lockDir
 
array $lockTypeMap
 Mapping of lock types to the type actually used. More...
 
- Protected Attributes inherited from LockManager
 $domain
 
array $locksHeld = []
 Map of (resource path => lock type => count) More...
 
 $lockTTL
 
array $lockTypeMap
 Mapping of lock types to the type actually used. More...
 

Private Member Functions

 closeLockHandles ($path, array $handlesToClose)
 
 pruneKeyLockFiles ($path)
 

Additional Inherited Members

- Public Attributes inherited from LockManager
const LOCK_EX = 3
 
const LOCK_SH = 1
 Lock types; stronger locks have higher values. More...
 
const LOCK_UW = 2
 

Detailed Description

Simple version of LockManager based on using FS lock files.

All locks are non-blocking, which avoids deadlocks.

This should work fine for small sites running off one server. Do not use this with 'lockDirectory' set to an NFS mount unless the NFS client is at least version 2.6.12. Otherwise, the BSD flock() locks will be ignored; see http://nfs.sourceforge.net/#section_d.

Since
1.19

Definition at line 36 of file FSLockManager.php.

Constructor & Destructor Documentation

FSLockManager::__construct ( array  $config)

Construct a new instance from configuration.

Parameters
array$configIncludes:
  • lockDirectory : Directory containing the lock files

Definition at line 55 of file FSLockManager.php.

FSLockManager::__destruct ( )

Make sure remaining locks get cleared for sanity.

Definition at line 240 of file FSLockManager.php.

References $path, as, and doSingleUnlock().

Member Function Documentation

FSLockManager::closeLockHandles (   $path,
array  $handlesToClose 
)
private
Parameters
string$path
array$handlesToClose
Returns
Status

Definition at line 197 of file FSLockManager.php.

References $path, $status, as, and Status\newGood().

Referenced by doSingleUnlock().

FSLockManager::doLock ( array  $paths,
  $type 
)
protected
See Also
LockManager::doLock()
Parameters
array$paths
int$type
Returns
Status

Definition at line 67 of file FSLockManager.php.

References $path, $status, $type, as, doSingleLock(), doUnlock(), and Status\newGood().

FSLockManager::doSingleLock (   $path,
  $type 
)
protected

Lock a single resource key.

Parameters
string$path
int$type
Returns
Status

Definition at line 109 of file FSLockManager.php.

References $path, $status, $type, getLockPath(), LockManager\LOCK_EX, LockManager\LOCK_SH, Status\newGood(), and wfMkdirParents().

Referenced by doLock().

FSLockManager::doSingleUnlock (   $path,
  $type 
)
protected

Unlock a single resource key.

Parameters
string$path
int$type
Returns
Status

Definition at line 154 of file FSLockManager.php.

References $path, $status, $type, closeLockHandles(), Status\newGood(), pruneKeyLockFiles(), and wfIsWindows().

Referenced by __destruct(), and doUnlock().

FSLockManager::doUnlock ( array  $paths,
  $type 
)
protected
See Also
LockManager::doUnlock()
Parameters
array$paths
int$type
Returns
Status

Definition at line 92 of file FSLockManager.php.

References $path, $status, $type, as, doSingleUnlock(), and Status\newGood().

Referenced by doLock().

FSLockManager::getLockPath (   $path)
protected

Get the path to the lock file for a key.

Parameters
string$path
Returns
string

Definition at line 233 of file FSLockManager.php.

Referenced by doSingleLock(), and pruneKeyLockFiles().

FSLockManager::pruneKeyLockFiles (   $path)
private
Parameters
string$path
Returns
Status

Definition at line 215 of file FSLockManager.php.

References $path, $status, getLockPath(), and Status\newGood().

Referenced by doSingleUnlock().

Member Data Documentation

array FSLockManager::$handles = []
protected

Map of (locked key => lock file handle)

Definition at line 47 of file FSLockManager.php.

FSLockManager::$lockDir
protected

Definition at line 44 of file FSLockManager.php.

array FSLockManager::$lockTypeMap
protected
Initial value:
= [
self::LOCK_SH => self::LOCK_SH

Mapping of lock types to the type actually used.

Definition at line 38 of file FSLockManager.php.


The documentation for this class was generated from the following file: