Redis雪崩

什么是缓存雪崩?

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

原因:

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

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

解决方案:

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

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

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

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

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

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

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

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

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

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

)

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

相关推荐
ketil2741 分钟前
Ubuntu 安装 redis
redis
王佑辉2 小时前
【redis】redis缓存和数据库保证一致性的方案
redis·面试
Karoku0662 小时前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
gorgor在码农3 小时前
Redis 热key总结
java·redis·热key
想进大厂的小王3 小时前
项目架构介绍以及Spring cloud、redis、mq 等组件的基本认识
redis·分布式·后端·spring cloud·微服务·架构
Java 第一深情3 小时前
高性能分布式缓存Redis-数据管理与性能提升之道
redis·分布式·缓存
minihuabei8 小时前
linux centos 安装redis
linux·redis·centos
monkey_meng10 小时前
【Rust中多线程同步机制】
开发语言·redis·后端·rust
hlsd#11 小时前
go 集成go-redis 缓存操作
redis·缓存·golang
奶糖趣多多13 小时前
Redis知识点
数据库·redis·缓存