概述
造成缓存雪崩的关键在于在同一时间大规模的key失效。
与缓存击穿不同的是缓存雪崩针对的是多个热点key,而缓存击穿是一个热点key
产生原因
第一种可能是Redis宕机,
第二种多个热点key可能是采用了相同的过期时间。
解决方案
1.过期时间设置随机值
在原有的失效时间上加上一个随机值,比如,1-5分钟随机。这样就避免了同一时间大量数据过期现象的发生而导致缓存雪崩。
2.分布式部署且均匀分布热点数据
如果缓存数据库是分布式部署,将热点数据均匀分布在不同搞得缓存数据库中。同时,分布式集群可以防止Redis宕机导致缓存雪崩的问题。
3.热点数据永不过期
设置热点数据永远不过期。
4.监控缓存过期,提前更新
监控缓存,发下缓存快过期了,提前对缓存进行更新。
5.使用锁或队列
用加锁或者队列的方式来保证不会有大量的线程对数据库一次性进行读写,从而避免失效时大量的并发
请求落到底层存储系统上,不适用高并发情况。
6.构建多级缓存
nginx缓存+redis缓存+其他缓存(ehcache等)
缓存雪崩的兜底措施:
1.使用熔断机制。当流量到达一定的阈值时,就直接返回“系统拥挤”之类的提示,防止过多的请求打在数据库上。至少能保证一部分用户是可以正常使用,其他用户多刷新几次也能得到结果