redis缓存雪崩、穿透、击穿、热点key分别代表什么

Redis逻辑 :先从缓存取,缓存有就直接返回,没有就查库,查到就存Redis没有就返回空。
缓存穿透
是针对数据库和缓存中都没有的数据。场景:当客户端发起查询时,缓存中没有就会去查库,库里也没有就会返回给客户端错误信息。这样是没问题 逻辑没毛病,但是存在一个漏洞 那就是无论什么样的key过来查我们都去接受他的请求这样就会被黑客抓住发起大量请求。并且Key都是我们系统中没有的,库里也查不到对应的值,这样的Key称之为非法key。那么当大量这样的请求过来时是不是会命中Redis然后都会打到DB上当DB瞬间接收到如此多的连接时DB就有可能撑不住了他就挂了。这就是存在的一个隐藏的漏洞,黑客或者恶意攻击者抓住这一点攻击你的系统使你的系统瘫痪。
实际开发中就要考虑这点,可以在系统层面加一层过滤,将系统认为非法的key进行一次拦截,直接返回给客户端错误信息。

缓存击穿
是针对缓存中没有但数据库有的数据。场景是当Key失效后假如瞬间突然涌入大量的请求,来请求同一个key这些请求不会命中Redis都会请求DB导致数据库压力过大,甚至扛不住,挂掉。
这个问题的解决方法是:
设置热点Key,自动检测热点eky,将热点key的过期时间加大或者设置为永不过期,或者设置为逻辑上永不过期。
2.加互斥锁 当发现没有命中Redis去查数据库的时候在执行官更新缓存的操作上加锁,谁拿到锁谁去更新,同时在拿到锁之后先从缓存再获取一次如果有就返回,没有就查库然后更新。

缓存雪崩
是指大量key同时失效对这些key的请求又会打到DB上同时导致数据库压力过大甚至挂掉。
这个问题解决方法:让key的失效时间分散开,可以在统一的失效时间上再加一个随机值,或者使用更高级的算法分散失效时间

热点key
针对热点数据,我们可以设置热点Key的过期时间很大或者在逻辑上永不过期
意思就是说假如我们设置热点数据过期时间为24小时,那么我们可以使用监听器去监听这些热点数据。当检测到它快要到期了异步起个线程去更新这个热点数据。可以达到逻辑上用不过期的效果。
另外 我们要有热点数据自动检测机制。即有个监控平台,来监控每个key某个时间段的请求次数,过期次数,查库次数,来分析这个key是不是热点数据,当达到某个阈值时将key升级为热点key然后走热点数据的逻辑。
在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值