
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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
融合Redis缓存的PostgreSQL高可用架构
梧桐
59次阅读
2025-04-08 06:35:40
国产非关系型数据库 Eloqkv 初体验
JiekeXu
48次阅读
2025-04-10 23:51:35
缓存监控治理在游戏业务的实践和探索
vivo互联网技术
45次阅读
2025-03-20 09:51:10
Redis 集群主备切换原因分析
wzf0072
38次阅读
2025-03-20 17:51:42
Redis 高可用方案
天翼云开发者社区
31次阅读
2025-03-24 17:09:54
Redis Cluster集群模式:构建大规模高性能分布式存储系统
老王两点中
31次阅读
2025-03-17 09:00:28
高并发场景下的库存管理,理论与实战能否兼得?
京东云开发者
18次阅读
2025-03-24 16:54:56
Redis Sentinel模式:构建高可用Redis集群
老王两点中
17次阅读
2025-03-14 09:01:04
Redis
鲁鲁
13次阅读
2025-04-07 20:14:35
Redis数据库——8种内存淘汰机制
编程Cookbook
13次阅读
2025-03-14 10:22:17