Redis穿透,雪崩的解决办法

1 篇文章 0 订阅

Redis是开发过程中经常使用到的工具,这里简单说一下如何解决穿透,雪崩的问题。
穿透:
1、利用互斥锁。缓存失效的时候,得到了锁,再请求数据库。没得到锁,休眠一段时间重试。
2、采用异步更新策略。无论key是否取到值,都直接返回。value值中维护一个缓存失效时间,缓存如果过期,异步一个线程去读数据库,跟新缓存。需要缓存预热(项目启动前,先加载缓存)。
3、提供一个能迅速判断请求是否有效拦截机制。如布隆过滤器,内部维护一系列合法有效的key,迅速判断出请求的key合不合法。

雪崩:
1、给缓存的失效时间加上随机值,避免集体失效。
2、利用互斥锁。但会导致吞吐量下降。
3、使用双缓存。一个设失效时间(A),一个不失效(B),做缓存预热。从A读数据库,有则直接返回;无就从B读,且异步启动一个更新线程,同时更新A,B。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值