首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

2023-06-27:redis中什么是缓存雪崩?该如何解决?

2023-06-27:redis中什么是缓存雪崩?该如何解决?

答案2023-06-27:

缓存雪崩是指当缓存层承载大量请求并有效保护存储层时,如果缓存层由于某些原因无法提供服务,例如缓存数据大面积失效,那一瞬间 Redis 就像不存在一样,导致所有请求都到达存储层。存储层的请求量急剧增加,可能导致存储层级联宕机的情况发生。

缓存雪崩,英文原意为"stampeding herd"(奔逃的兽群),形象地比喻了缓存层宕掉后,流量会像奔逃的兽群一样,涌向后端存储层。

预防和解决缓存雪崩问题,可以从以下四个方面入手:

1)确保缓存层的高可用性。与一架飞机拥有多个引擎类似,如果设计一个高可用的缓存层,即使个别节点、机器甚至整个机房宕掉,仍能提供服务。例如,Redis Sentinel和Redis Cluster都实现了高可用性。

2)依赖隔离组件进行后端流量限制和降级。无论是缓存层还是存储层,都存在出错的概率。将它们视为资源,并对并发较高的系统进行限流和降级,防止一个资源的不可用性导致线程阻塞(hang),从而造成整个系统不可用。

3)提前进行演练。在项目上线之前,进行缓存层宕掉后、应用和后端负载情况以及可能出现的问题的演练,以便制定相应预案。

4)随机分散缓存失效时间。例如,在原有失效时间的基础上增加一个随机值,如1-5分钟的随机范围,使每个缓存过期时间的重复率降低,从而减少集体失效事件的发生。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20230627A077CQ00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券