Redis雪崩

什么是缓存雪崩?

就是缓存失效了,使得大量的请求落在了数据库上,然后导致数据库扛不住那么大的访问,直接崩了

原因:

1.缓存的服务器宕机,因为停电或者服务器本身一些原因等,或者硬件啥问题等

2.因为缓存同一时间失效,key的设置策略有点问题,key的过期时间应该随机设置

解决方案:

1.缓存预热: 对刚开启的服务,通过算法限制其不能访问数据库,等待数据从数据库中加载到缓存中,然后才能访问

2.key的存活时机随机,避免缓存同一时间失效

3.分布式锁,通过锁来控制访问量

4.Redis集群,通过Redis的集群,采用redis的哨兵,提高redis的高可用性,而不是采用主从模式

5.限流和降级,通过限流和降级策略,来保护后端系统,防止后端系统崩溃

6.设置备份缓存,也就是二级缓存,即便主缓存出问题了,那么副缓存可以顶上去

7.异步加载:使用异步加载到redis,减少对实时时间的依赖

(在这简单说一下什么是同步和异步吧?

同步就是系统发出请求之后,必须等到响应,有了响应之后,系统才能做下一件事

异步的话不同就是系统发出请求之后,无须等待响应,就可以做下一件事了,到时候响应通知就行了,这样就提高了效率,

)

8.监控和自动扩展资源,通过监控缓存的性能指标,如果发现资源不够用了,那么自动扩展资源

相关推荐
见山是山-见水是水1 小时前
鸿蒙flutter第三方库适配 - 汇率换算器
redis·flutter·华为·harmonyos
014-code1 小时前
Redis 删除缓存失败怎么办?重试、死信、补偿的工程化方案
数据库·redis·缓存
rannn_1112 小时前
【Redis|高级篇1】分布式缓存|持久化(RDB、AOF)、主从集群、哨兵、分片集群
java·redis·分布式·后端·缓存
PD我是你的真爱粉2 小时前
Redis 持久化、过期删除、淘汰策略与内存碎片全解析
java·redis·bootstrap
斌味代码2 小时前
Redis 分库分表实战:从垂直拆分到水平扩容完整记录
数据库·redis·bootstrap
rchmin2 小时前
阿里Tair分布式锁与Redis分布式锁的实现区别
数据库·redis·分布式
win x11 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
程序员萌萌16 小时前
Redis的缓存机制和淘汰策略详解
数据库·redis·缓存机制·淘汰策略
深蓝电商API1 天前
Redis在海淘场景下的缓存策略设计
数据库·redis·缓存·海淘
杰克尼1 天前
redis(day04-达人探店)
数据库·redis·缓存