加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

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

发布时间:2020-12-13 02:32:11 所属栏目:PHP教程 来源:网络整理
导读:《:PHP中使用Memache作为进程锁的操作类分享》要点: 本文介绍了:PHP中使用Memache作为进程锁的操作类分享,希望对您有用。如果有疑问,可以联系我们。 ?php// 使用Memache 作为进程锁 class lock_processlock{ // key 的前缀 protected $sLockKeyPre; //

《:PHP中使用Memache作为进程锁的操作类分享》要点:
本文介绍了:PHP中使用Memache作为进程锁的操作类分享,希望对您有用。如果有疑问,可以联系我们。

<?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;
 }
 
 
 /*
 向MeMcache中添加 key
 */
 public addMemcache($sKey,$sValue,$iTimeout){
  
  for($i= 0 ; $i<$this->iMemcacheRetryCount){
   $bRes = $this->oMemcache->add($sKey,$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 ; 
   }
   
   // 如果加锁不成功,从新加锁
   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);

编程之家PHP培训学院每天发布《:PHP中使用Memache作为进程锁的操作类分享》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读