Redis缓存雪崩、击穿、穿透、到底是什么?

今日目标

  • 能够掌握Redis缓存雪崩概念及解决方案
  • 能够掌握Redis缓存击穿概念及解决方案
  • 能够掌握Redis缓存穿透概念及解决方案

一、场景

在今天的互联网里,高并发、大数据量、大流量已经成为了代言词,那么我们的系统也承受着巨大的压力,首当其冲的解决方案就是redis。 那么redis使用不当就会产生雪崩、穿透、击穿等问题,这也是考验一个程序员技术能力的时刻。 当然面试的时候,这也是高频面试题,几乎大厂都会问到。下面跟着贴心老哥一起来看看这些技术吧。

二、缓存雪崩

image

1.举例

双十一期间,所有用户一打开淘宝就是进入首页,首页的压力非常大,为了提高并发,将网站首页数据都缓存到redis里,所有的redis key失效时间都是3小时。 双十一当天大量用户剁手狂欢,这时候3个小时过去了,redis里首页的key缓存全部失效,这时候redis里查询不到数据了,只能去数据库中查询,造成数据库无法响应挂掉。 用户进不去首页没法剁手了,马爸爸就不开心了,把这个程序员外派到非洲了。

image

2.一句话总结

在高并发下,大量缓存key在同一时间失效,大量请求直接落在数据库上,导致数据库宕机。

3.解决方案
  • 随机设置key失效时间,避免大量key集体失效。setRedis(Key,value,time + Math.random() * 10000);
  • 若是集群部署,可将热点数据均匀分布在不同的Redis库中也能够避免key全部失效问题
  • 不设置过期时间
  • 跑定时任务,在缓存失效前刷进新的缓存

三、缓存穿透

image

1.举例

老哥做了一个网站火了,动了别人的蛋糕,于是开始疯狂攻击老哥的网站,由于老哥网络安全方面学艺不精被人钻了空子。

某人用脚本疯狂的给老哥发送请求,查询 id = -1 的数据,redis并没有这样的数据,这时候就穿透redis,直接打到了数据库上。

半夜老哥在睡觉并没有察觉,他疯狂攻击老哥一晚上,结果把数据库搞挂了,然后老哥的网站也挂了。

2.一句话总结

redis缓存和数据库中没有相关数据(例用户直接携带id<=0的参数不断发起请求),redis中没有这样的数据,无法进行拦截,直接被穿透到数据库,导致数据库压力过大宕机。

3.解决方案
  • 对不存在的数据缓存到redis中,设置key,value值为null(不管是数据未null还是系统bug问题),并设置一个短期过期时间段,避免过期时间过长影响正常用户使用。
  • 拉黑该IP地址
  • 对参数进行校验,不合法参数进行拦截
  • 布隆过滤器 将所有可能存在的数据哈希到一个足够大的bitmap(位图)中,一个一定不存在的数据会被 这个bitmap拦截掉,从而避免了对底层存储系统的查询压力。

四、缓存击穿

image

1.举例

双十一马爸爸突发奇想,想拍卖自己穿了20年的老布鞋,并且附带本人签名,程序员将该鞋的信息存到了redis中,设置了3小时过期。寻思3小时够他们抢了吧,但他低估了马爸爸的魅力。

该商品引起了一千万人关注,这些人不断的竞拍这双鞋,价格越拍越高,马爸爸乐开了花。

竞拍了2小时59分,马上要拍到一个亿了,突然这双鞋在redis里的key数据过期了,导致该key的大量请求,都打到了数据库,直接导致数据库挂掉了,服务无法响应。

竞拍到此结束,鞋没卖出去,马爸爸又不开心了,把这个程序员也外派到非洲了。

image

2. 一句话总结

某一个热点key,在不停地扛着高并发,当这个热点key在失效的一瞬间,持续的高并发访问就击破缓存直接访问数据库,导致数据库宕机。

3.解决方案
  • 设置热点数据"永不过期"
  • 加上互斥锁:上面的现象是多个线程同时去查询数据库的这条数据,那么我们可以在第一个查询数据的请求上使用一个互斥锁来锁住它。 其他的线程走到这一步拿不到锁就等着,等第一个线程查询到了数据,然后将数据放到redis缓存起来。后面的线程进来发现已经有缓存了,就直接走缓存 最后总结 雪崩是大面积的key缓存失效;穿透是redis里不存在这个缓存key;击穿是redis某一个热点key突然失效,最终的受害者都是数据库。

五、思考

  • 未雨绸缪:将redis、MySQL等搭建成高可用的集群,防止单点。
  • 亡羊补牢:服务中进行限流 + 降级,防止MySQL被打崩溃。
  • 重振旗鼓:Redis 持久化 RDB+AOF,宕机重启,自动从磁盘上加载数据,快速恢复缓存数据。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Redis缓存雪崩穿透击穿是指在使用Redis作为缓存的过程中可能会遇到的一些问题。 缓存雪崩是指当缓存中大量的数据在同一时间内失效或者缓存服务宕机,导致大量请求直接落到数据库上,从而使得数据库瞬间压力过大,甚至瘫痪的情况。 缓存穿透是指当请求的数据在缓存中不存在,且数据库中也不存在该数据,这时请求会直接落到数据库上,这会导致大量无效的请求访问数据库,从而使得数据库瞬间压力过大,甚至瘫痪的情况。 缓存击穿是指某个热点key在缓存中失效的同时,有大量的请求并发地访问这个key,这时候这些请求会直接落到数据库上,从而使得数据库瞬间压力过大,甚至瘫痪的情况。 ### 回答2: Redis缓存雪崩是指在缓存失效的情况下,大量请求同时涌入数据库,造成数据库压力过大的现象。在缓存失效期间,如果有大量请求访问同一数据,这些请求会直接访问数据库,导致数据库无法承受这么大的请求量,进而影响系统的正常运行。 Redis缓存穿透是指恶意请求经过缓存层,直接访问数据库。如果有恶意攻击者发送请求,而这些请求的key并不存在于缓存数据库中,每次请求都会直接访问数据库,这将导致数据库负担过重,对系统造成损害。 Redis缓存击穿是指缓存中某个key失效的同时,有大量的请求同时访问这个key,请求会直接访问数据库。与缓存雪崩不同的是,缓存击穿是因为某个热点数据的缓存过期,导致大量请求直接访问数据库,而不是所有缓存同时失效。 为了解决缓存雪崩问题,可以采取以下措施:1. 设置缓存的过期时间时,可以使用不同的随机值,避免缓存同时失效。2. 使用分布式锁来控制对数据库的并发访问,避免压力集中在某个时间段。3. 预加载缓存,提前将热点数据加载到缓存中,减少缓存失效的可能性。 为了解决缓存穿透问题,可以采取以下措施:1. 对于不存在的key,在缓存中设置一个空值,避免重复的查询数据库。2. 使用布隆过滤器,在缓存层对请求进行过滤,判断key是否存在,避免查询数据库。 为了解决缓存击穿问题,可以采取以下措施:1. 设置热点数据的永不过期,保证它们的缓存一直有效。2. 使用互斥锁,在缓存失效的时候,只允许一个请求访问数据库,其他请求等待结果。3. 使用一级缓存和二级缓存的结构,将热点数据存储在一级缓存中,保证其高效访问。 ### 回答3: Redis缓存雪崩是指在某个时间段内,缓存中的大量数据同时过期或失效,导致大量请求直接打到数据库上,从而引起数据库瞬时压力过大,造成系统性能下降甚至崩溃。 Redis缓存穿透是指恶意请求或非法请求经过缓存层,直接查询数据库获取不到数据,从而导致大量请求落到数据库上,增加数据库压力,造成系统响应缓慢甚至瘫痪。 Redis缓存击穿是指某个热点数据突然失效或被删除,导致大量并发请求同时查询该数据,由于缓存中不存在该数据,请求都会直接打到数据库上,造成数据库瞬时压力过大,可能导致系统宕机。 为了解决缓存雪崩问题,可以采取以下措施: 1. 设置缓存失效时间时使用随机值,避免大量缓存同时失效。 2. 使用分布式锁,保证只有一个线程去加载数据到缓存。 3. 设置热点数据永不过期,确保重要数据始终可用。 为了避免缓存穿透,可以采取以下措施: 1. 对请求数据的合法性进行校验,过滤掉非法请求。 2. 对于查询不到的数据,也将空结果缓存一段时间,避免频繁查询数据库。 为了防止缓存击穿,可以采取以下措施: 1. 使用互斥锁,保证只有一个线程去查询数据库,其他线程等待结果。 2. 引入熔断机制,当热点数据失效时,暂时不提供服务,避免大量请求落到数据库上。 3. 针对热点数据设置短期的锁定时间,避免大量请求同时查询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值