PHP中使用Memache作为进程锁的操作类分享

时间:2021-05-26

<?php// 使用Memache 作为进程锁 class lock_processlock{ // key 的前缀 protected $sLockKeyPre; // 重试间隔 protected $iLockRetryInterval; //重试次数 protected $iLockRetryCount; //锁的过期时间 protected $iLockCacheTimeout; // 锁过期后的回调函数 protected $onLockTimeoutFunc; // memache 的实例 protected $oMemcache; // 存储memcache失败后重试次数 protected $iMemcacheRetryCount; public function __construct ($onLockTimeoutFunc=NULL) { $aLockConfig = get_config('', 'lock'); $this->sLockKeyPre = self::LOCK_KEY_PRE; $this->iLockRetryInterval = self::LOCK_RETRY_INTERVAL; $this->iLockRetryCount =self::LOCK_RETRY_COUNT; $this->iLockCacheTimeout = self::LOCK_CACHE_TIMEOUT; $this->iMemcacheRetryCount = self::LOCK_CACHE_TIMEOUT; if(!$onLockTimeoutFunc){ // 如果加锁不成功则调用回调函数,如果没有回调函数,使用本类中所带的 $onLockTimeoutFunc ='onLockTimeout' ; } $this->onLockTimeoutFunc = $onLockTimeoutFunc; } /** 连接memcache 服务器 */ public function connect() { if (! isset ( $this->oMemcache )) { $this->oMemcache = new Memcache (); $this->oMemcache->connect ( '127.0.0.1', 11211 ); } return $this->oMemcache; } public addMemcache($sKey, $sValue, $iTimeout){ for($i= 0 ; $i<$this->iMemcacheRetryCount){ $bRes = $this->oMemcache->add($sKey, $sValue, $iTimeout); if($bRes){ return true ; } // 如果加锁不成功,sleep 之后,从新加锁 usleep($this->iLockRetryInterval*1000); } return false ; } public function lock($sLockID){ $oMemcache = $this->connect(); $sKey = $this->sLockKeyPre . $sLockID; // 加锁如果不成功可以多试几次 for($i = 0 ; $i <$this->iLockRetryCount ; $i++){ // 这里设置value 的值可以随便设置 if($this->addMemcache($sKey,'1',$this->iLockCacheTimeout)){ return true ; } // 如果加锁不成功,sleep 之后,从新加锁 usleep($this->iLockRetryInterval*1000); } // 若还不成功,则加锁失败,调用回调函数,.也就是失败后需要处理的操作 if(is_callable($this->onLockTimeoutFunc)){ // 调用函数 call_user_func($this->onLockTimeoutFunc); } } public function unlock($sLockID){ $oMemcache = $this->connect(); $sKey = $this->sLockKeyPre . $sLockID; // 删除key return $this->oMemcache->delete($sKey); } /** 如果加锁不成功,则执行如下操作 */ public function onLockTimeout(){ echo ("加锁超时"); } }// 应用实例 $oLock = new lock_processlock(); $lockResource = "test"; // 加锁 $oLock->lock($lockResource); // 解锁 $oLock->unlock($lockResource);

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章