PHP抽奖活动加内存锁,原理是什么?如何实现?
public function acquire($key) {
//如果需要同时获取两个锁
if ( is_array($key) && count($key) == 2 ) {
while (TRUE) {
$res = array();
foreach($key as $k => $v) {
$res[$k] = $this->acquire($v);
if ( !$res[$k] ) {
break;
}
}
//若第一个锁未拿到则直接返回
if ( !$res[0] ) {
$err = new SysErr(System::MEMCACHE_ACQUIRE_LOCK_ERROR);
ErrorHandle::throwErr($err);
} elseif( !$res[1] ) {
//释放第一个锁,等待然后重试
$this->release($key[0]);
usleep(LockConfig::LOCK_TIMEWAIT);
} else {
return TRUE;
}
}
} else {
$lock_key = LockConfig::LOCK_PREFIX . $key;
$i = 0;
do {
$lock = $this->_memcache->add( $lock_key, 1, LockConfig::LOCK_TIMEOUT );
//如果第一次没有获取到锁则等待指定时间后重试
if ($i > 0) {
usleep(LockConfig::LOCK_TIMEWAIT);
}
$i++;
//超过重试次数后退出
if ($i > LockConfig::LOCK_RETRY_TIMES) {
$err = new SysErr(System::MEMCACHE_ACQUIRE_LOCK_ERROR);
ErrorHandle::throwErr($err);
}
} while( !$lock );
// 记录log
if ($i > 1) {
LogHelper::warning('lock.log', "Acquire lock '{$lock_key}' for {$i} times");
}
return $lock;
}
}
/**
* 释放内存锁
*
* @param string $key 内存锁去除前缀后的key值
* @return bool 释放成功返回TRUE
*/
public function release($key) {
$lock_key = LockConfig::LOCK_PREFIX . $key;
return $this->_memcache->delete($lock_key);
}
为情所困2017-05-16 13:11:23
복권에는 메모리락이 필요하지 않습니다. Redis 대기열 또는 트랜잭션을 사용하고 Mysql 잠금을 추가할 수 있어야 합니다. .
원하는 메모리 잠금이 이것이었는지 모르겠습니다:
$lock = new CacheLock('key_name')
$lock->lock();
//logic here
$lock->unlock( );
CacheLock 프로세스 잠금은 캐시가 과도한 SQL 요청이 데이터베이스에 침투하는 것을 방지하지 못할 때 주로 단일 프로세스 캐시 획득에 사용됩니다. 동시성 중 PHP의 잠금 제어를 해결하고 파일을 통해 프로세스 간 잠금을 수행하는 데 사용됩니다. /eaccelerator. 그렇지 않은 경우 eaccelerator를 사용하여 파일 잠금을 처리하고 해당 디렉터리에 해당 세분성으로 잠금을 생성합니다. eaccelerator를 사용하면 처리가 메모리에서 수행되며 성능은 행과 유사하게 상대적으로 높습니다. mysql innodb의 레벨 잠금.