一个简单的PHP REDIS分布式锁类 外部使用获取锁和释放锁来处理自己的业务逻辑即可
/**
* Class DistributedLocks 基于redis的分布式锁
*/
class DistributedLocks
{
/**
* 获取锁函数
* @param $key string 锁key
* @param $expire string 锁定的时间
* @return bool 获取结果 失败false 成功true 外面做业务逻辑处理
*/
public function lock($key, $expire)
{
// 判断参数是否为空
if (empty($key) || empty($expire)) {
return false;
}
$redis = Predis::getInstance();
$result = $redis->get($key);
if (!$result) {
// 如果没有值 设置值
$lock_result = SETNX($key, time() + $expire);
if ($lock_result) {
// 加锁成功 设置过期时间
$redis->expire($key, $expire);
return true;
}
} else {
// 有值 判断是否 过期 防止死锁
if ($redis->get($key) < time()) {
// 上锁判断上一个值是否过期 防止其他进程已经上锁
if ($redis->getSet($key, time() + $expire) < time()) {
$redis->expire($key, $expire);
return true;
}
}
}
return false;
}
/**
* 释放锁函数
* @param $key string 锁key
* @return bool 释放结果
*/
public function release($key)
{
$redis = Predis::getInstance();
if ($redis->ttl($key)) {
$redis->del($key);
}
return true;
}
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。