雪崩是大面积
的key缓存失效;
穿透是redis里不存在
这个缓存key;
击穿是redis某一个热点
key突然失效;
最终的受害者都是数据库
雪崩:
在高并发
下,大量缓存在redis中的key在同一时间失效
,导致大量请求直接请求到数据库上,导致数据库宕机。
解决方案
- 随机设置key失效时间,避免大量key集体失效。
setRedis(Key,value,time + Math.random() * 10000); 复制代码
- 若是集群部署,可将热点数据均匀分布在不同的Redis库中也能够避免key全部失效问题
- 不设置过期时间
- 跑定时任务,在缓存失效前刷进新的缓存
穿透:
用户查询的数据在redis缓存
和数据库
中均没有相关数据(例用户直接携带id<=0
的参数不断发起请求),redis中没有这样的数据,无法进行拦截
,直接被穿透到数据库,大量到请求频繁穿透的数据库
,导致数据库压力过大宕机。
解决方案
- 对不存在的数据缓存到redis中,设置key,value值为null(不管是数据未null还是系统bug问题),并设置一个短期过期时间段,避免过期时间过长影响正常用户使用。
- 拉黑该IP地址
- 对参数进行校验,不合法参数进行拦截
击穿:
热点数据key,在不停地扛着高并发,当这个热点key在失效的一瞬间
,持续的高并发访问就击破缓存
直接访问数据库,导致数据库宕机。
解决方案
- 设置热点数据"永不过期"
- 加上互斥锁:上面的现象是多个线程同时去查询数据库的这条数据,那么我们可以在第一个查询数据的请求上使用一个互斥锁来锁住它
其他的线程走到这一步拿不到锁就等着,等第一个线程查询到了数据,然后将数据放到redis缓存起来。后面的线程进来发现已经有缓存了,就直接走缓存
参考: Redis的雪崩,击穿,穿透详解_希望之光芒的博客-CSDN博客