当前位置:   article > 正文

在 Laravel 中使用 Redis 锁解决缓存击穿问题_laravel redis->lock

laravel redis->lock

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

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

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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

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

使用示例:

use Illuminate\Support\Facades\Redis;
use Illuminate\Cache\RedisLock;
  • 1
  • 2
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;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/449287
推荐阅读
相关标签
  

闽ICP备14008679号