【Redis篇】Redis缓存之缓存雪崩

1 缓存雪崩

1.1 缓存雪崩的定义

缓存雪崩是指在同一时段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。

1.2 解决方案

1.2.1 大量的缓存key同时失效

【Redis篇】Redis缓存之缓存雪崩_第1张图片
给不同的Key的TTL添加随机值,比如将缓存失效时间分散开,可以在原有的失效时间基础上增加一个随机值,比如1-5分钟随机,这样每一个缓存的过期时间的重复率就会降低,就很难引发集体失效的事件。

1.2.2 Redis服务宕机

【Redis篇】Redis缓存之缓存雪崩_第2张图片
①利用Redis集群提高服务的可用性,比如哨兵模式、集群模式;
②给缓存业务添加降级限流策略,比如可以在ngxin或spring cloud gateway中处理;(注:降级可做为系统的保底策略,适用于穿透、击穿、雪崩
③给业务添加多级缓存,比如使用Guava或Caffeine作为一级缓存,redis作为二级缓存等;

你可能感兴趣的:(Java面试宝典,缓存,redis,java)