一文带你了解什么是Redis缓存雪崩,缓存击穿,缓存穿透及其解决方案

本次我们来聊一下面试中关于Redis的高频面试题,缓存雪崩,缓存击穿,缓存穿透;

缓存雪崩

假设服务器每秒处理五千并发,其中四千个请求都是读操作,一千个写操作,使用缓存将四千个读操作缓存起来,避免了大量请求同时请求数据库,保证了系统的安全,但是突然redis服务器宕机了,导致所有的请求都直接请求了数据库,从而导致DB承受不住并发然后挂了,接连导致系统不可用。这就是缓存雪崩。

解决方案

事前:redis实现高可用,主从+哨兵,或 集群模式,避免redis宕机。

事中:本地缓存+程序内实现限流,避免大量请求同时请求DB导致数DB宕机

事后:redis持久化,保存内存数据,启动服务时快速恢复数据到内存中

缓存穿透

用户或黑客恶意发起请求内存和DB中都不存在的数据,导致每次的请求在缓存中查不到后继续取请求DB,这种的恶意攻击就会穿过缓存直接将DB打死。

解决方案

首先可以通过布隆过滤器,先对请求进行筛选,判断是否是合法的请求,如果请求在库中肯定不存在,就直接返回,不再去请求DB。

因为布隆过滤器有一定的几率会判断失误,那么就可以将用户请求的这个不存在的值添加到缓存中,并赋给一个较短的过期时间。

缓存击穿

假设某一个key每秒都抗住了一万次的请求,访问非常频繁,但是这个key突然到达了设置的失效时间,导致了大量的请求就穿过了缓存,直接就请求到了DB,从而导致DB承受不住压力而宕机。

解决方案

若缓存的数据是长期不会更新的,就可以将这个热点的key设置为永不过期,当有修改该值时,直接从缓存中修改

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值