时间: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邮箱联系删除。
本文实例讲述了PHP+redis实现的悲观锁。分享给大家供大家参考,具体如下:锁机制通常使用的锁分为乐观锁,悲观锁这两种,简单介绍下这两种锁,作为本文的背景知识
本文实例讲述了PHP基于文件锁解决多进程同时读写一个文件问题。分享给大家供大家参考,具体如下:首先PHP是支持进程的而不支持多线程(这个先搞清楚了),如果是对于
前言python调用php代码实现思路:php文件可通过在terminal中使用php命令行进行调用,因此可使用python开启子进程执行命令行代码。函数所需的
本文实例讲述了PHP将进程作为守护进程的方法。分享给大家供大家参考。具体分析如下:php中posix_setsid()的用法文档解释是“Makethecurre
本文实例讲述了php多进程中的阻塞与非阻塞操作。分享给大家供大家参考,具体如下:我们通过pcntl_fork来创建子进程,使用pcntl_wait和pcntl_