Redis Lock

这里的锁,并不是进程锁,也不是文件锁,而是基于Redis做的一种加锁形式,用户锁住所在操作的状态。然而,由于并不是真正意义上的原子锁,只是利用Redis在内存中的快速读写,进而实现的机制,因而存在一定限制,在突破一定读写速率后,该机制会失效。因此,在严谨的性能需求中,不建议使用。

以下,基于Laravel门面的代码:

    /**
     *  Redis 加锁
     *
     *  @param  string $key    锁状态标识
     *  @param  int    $expire 自动解锁时间
     *  @return bool 
     */
    public function lockKey($key, $expire)
    {
        $lockStatus = Redis::get($key);
        if($lockStatus == 1){
            return false;  //这个 $key 已经存在加锁
        }else{
            Redis::setex($key, $expire, 1);  //当前 key 的过期时间设为 $expire 秒,当值为 1 时,即锁住
            return true;
        }
    }

    /**
     *  Redis 解锁
     *
     *  @param string $key 锁状态标识
     */
    public function unlockKey($key)
    {
        if(Redis::exists($key))
            Redis::del($key);
    }

在需要一个隔离,或者事务的代码模块,或者接口,你需要的只是简单的利用 Redis 加个锁。

 

转载本文,请注明出处、作者。

你可能感兴趣的:(经验)