1

一个简单的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;
    }
}

github地址


colasjun
59 声望1 粉丝

积累知识 胜过积蓄金银