
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;}}

现在可以留言了
▼请点击下方:“阅读原文”,在线查看!


文章评论