redis缓存穿透,缓存雪崩

  1. 缓存击穿

    1. 现象:恶意用户模拟请求很多缓存中不存在的数据,由于缓存中都没有,导致这些请求短时间内都直接落到了数据库上,导致数据库压力过大,崩掉

    2. 解决方案:
      1. 布隆过滤器: bloomfilter可以快速判断key是否存在于容器,不存在就直接返回
      2. 使用互斥锁队列: 根据key获取value值为空时,锁上,从数据库中load数据后在释放锁
  2. 缓存雪崩

    1. 缓存在同一时间内,大量key过期,接下来一大波请求瞬间都落在数据库中,导致数据库挂掉
      1. 建立备份缓存,缓存A和B,A设置超时,B不设置超时时间,先从A读缓存,A没有读B,并且更新A缓存和B缓存
      2. 使用互斥锁队列: 根据key获取value值为空时,锁上,从数据库中load数据后在释放锁

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值