暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

在Laravel中使用Redis锁解决缓存击穿问题

php中文网最新课程 2020-09-14
1136

php中文网最新课程

每日17点准时技术干货分享

缓存击穿是开发中可能会遇到的问题:

缓存击穿是指缓存中没有但数据库中有的数据(一般是缓存时间到期),这时由于并发用户特别多,同时读缓存没读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大,造成过大压力。

Redis锁是解决缓存击穿问题的一个很好的办法。

Laravel 7 中自带有 \Illuminate\Cache\RedisLock
 Redis锁类,直接使用就行,用起来也很方便。

RedisLock
 的构造函数如下:

    /**
    * @param \Illuminate\Redis\Connections\Connection $redis redis实例
    * @param string $name redis锁的键名
    * @param int $seconds redis锁的失效时间
    * @param string|null $owner redis锁的值,如果不设置或者为null,基类会将其设置为随机字符串
    */public function __construct($redis, $name, $seconds, $owner = null){
    parent::__construct($name, $seconds, $owner);
    $this->redis = $redis;}
    复制

    在这个类中,使用 acquire()
     方法获得互斥的Redis锁,使用 release()
     方法释放锁。

    使用示例:

      use Illuminate\Support\Facades\Redis;use Illuminate\Cache\RedisLock;
      复制
        function RedisLockTest(){
        //获取redis实例
        $redis = Redis::connection();
        $key = 'redis_test_key';
        //获取redis锁实例
        $redisLock = new RedisLock($redis, $key . '_lock', 30);
        $res = $redis->get($key);
        if (empty($res)) {
        //拿到互斥锁
        if ($redisLock->acquire()) {
        //模拟从数据库中获取数据的过程
        sleep(5);
        $value = date('Y-m-d H:i:s');
        //更新缓存,过期时间可以根据实际情况调整
        $redis->setex($key, 60, $value);
        //释放锁
        $redisLock->release();
        return $value;
        } else {
        //等待2秒,然后重新获取缓存值,让其他获取到锁的进程取得数据并设置缓存,等待时间可以根据实际情况调整
        sleep(2);
        return $this->RedisLockTest();
        }
        } else {
        return $res;
        }}
        复制

        请点击下方:“阅读原文”,在线查看!

        文章转载自php中文网最新课程,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

        评论