缓存穿透、击穿、雪崩

一、缓存穿透

缓存穿透指的是大量请求缓存中不存在的数据,直接访问数据库,造成数据库压力过大,会使别的用户的正常请求时间过长,效率低下。

解决方法

1.设置空key,请求访问数据库不存在后在redis中设置一个key value设置为null,缺点是比较浪费空间。

2.布隆过滤器

存在的问题:

这样会存在一个问题,如果并发很多请求,因为redis是串行的,设置空value是在串行的请求结束之后进行的。那时候这样串行的请求已经全部打在数据库了。解决办法就是加上分布式锁,如果redis没有缓存,就去抢锁,同一时刻只有一个请求能抢到锁,这样请求到数据库中的只有一个请求,就避免了数据库的压力

二、缓存击穿

热点key过期(或者从来没有被缓存的),数据库存在数据,但是redis没有缓存,有大量的并发到达db。

解决办法

其实和缓存穿透一样的问题,一样的解决办法,主要就是添加分布式锁。

三、缓存雪崩

大量的key在同一时间失效,请求全部打在db

解决办法

简单的就是采用合理的过期时间了,复杂点的就是和上面两个问题一样采用分布式锁解决

四、两个问题的解决步骤步骤

1、请求redis没有数据
2、并发抢锁
3、抢到锁的请求db
4、没抢到的sleep
5、更新redis
6、回到第一步再请求redis就有数据了

以上问题,核心就是避免DB无效/重复请求,结合图去理解
涉及一些架构思想上的提升

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

谢少迪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值