什么是缓存雪崩、缓存击穿、缓存穿透

缓存雪崩

什么是缓存雪崩

当某一个时刻出现大规模的缓存失效的情况,那么就会导致大量的请求直接打在数据库上面,导致数据库压力巨大,如果在高并发的情况下,可能瞬间就会导致数据库宕机。这时候如果运维马上又重启数据库,马上又会有新的流量把数据库打死。这就是缓存雪崩。

在这里插入图片描述

分析:

造成缓存雪崩的关键在于在同一时间大规模的key失效。为什么会出现这个问题呢,有几种可能,第一种可能是Redis宕机,第二种可能是采用了相同的过期时间。搞清楚原因之后,那么有什么解决方案呢?

解决方案:

1、在原有的失效时间上加上一个随机值,比如1-5分钟随机。这样就避免了因为采用相同的过期时间导致的缓存雪崩。

如果真的发生了缓存雪崩,有没有什么兜底的措施?

2、使用熔断机制。当流量到达一定的阈值时,就直接返回“系统拥挤”之类的提示,防止过多的请求打在数据库上。至少能保证一部分用户是可以正常使用,其他用户多刷新几次也能得到结果。

3、提高数据库的容灾能力,可以使用分库分表,读写分离的策略。

4、为了防止Redis宕机导致缓存雪崩的问题,可以搭建Redis集群,提高Redis的容灾性。

缓存击穿

什么是缓存击穿?

其实跟缓存雪崩有点类似,缓存雪崩是大规模的key失效,而缓存击穿是一个热点的Key,有大并发集中对其进行访问,突然间这个Key失效了,导致大并发全部打在数据库上,导致数据库压力剧增。这种现象就叫做缓存击穿。

分析:

关键在于某个热点的key失效了,导致大并发集中打在数据库上。所以要从两个方面解决,第一是否可以考虑热点key不设置过期时间,第二是否可以考虑降低打在数据库上的请求数量。

解决方案:

1、上面说过了,如果业务允许的话,对于热点的key可以设置永不过期的key。

2、使用互斥锁。如果缓存失效的情况,只有拿到锁才可以查询数据库,降低了在同一时刻打在数据库上的请求,防止数据库打死。当然这样会导致系统的性能变差。

缓存穿透

什么是缓存穿透?

我们使用Redis大部分情况都是通过Key查询对应的值,假如发送的请求传进来的key是不存在Redis中的,那么就查不到缓存,查不到缓存就会去数据库查询。假如有大量这样的请求,这些请求像“穿透”了缓存一样直接打在数据库上,这种现象就叫做缓存穿透。

分析:

关键在于在Redis查不到key值,这和缓存击穿有根本的区别,区别在于缓存穿透的情况是传进来的key在Redis中是不存在的。假如有黑客传进大量的不存在的key,那么大量的请求打在数据库上是很致命的问题,所以在日常开发中要对参数做好校验,一些非法的参数,不可能存在的key就直接返回错误提示,要对调用方保持这种“不信任”的心态。

解决方案:

在这里插入图片描述

1、把无效的Key存进Redis中。如果Redis查不到数据,数据库也查不到,我们把这个Key值保存进Redis,设置value=“null”,当下次再通过这个Key查询时就不需要再查询数据库。这种处理方式肯定是有问题的,假如传进来的这个不存在的Key值每次都是随机的,那存进Redis也没有意义。

2、使用布隆过滤器。布隆过滤器的作用是某个 key 不存在,那么就一定不存在,它说某个 key 存在,那么很大可能是存在(存在一定的误判率)。于是我们可以在缓存之前再加一层布隆过滤器,在查询的时候先去布隆过滤器查询 key 是否存在,如果不存在就直接返回。
在这里插入图片描述

在这里插入图片描述

  • 22
    点赞
  • 88
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
### 回答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. 针对热点数据设置短期的锁定时间,避免大量请求同时查询。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

MonkeyKing.sun

对你有帮助的话,可以打赏

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

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

打赏作者

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

抵扣说明:

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

余额充值