缓存预热&缓存雪崩&缓存击穿&缓存穿透
一、缓存预热
提前将数据从数据库同步到redis。
- 在程序启动的时候,直接将数据刷新到redis
- 懒加载,用户访问的时候,第一次查询数据库,然后将数据写入redis
二、缓存雪崩
- 发生情况
- redis主机挂了,redis全盘崩溃,偏硬件运维
- redis中有大量key同时过期或大面积失效,偏软件开发
- 预防&解决方法
- redis中key设置永不过期,或者过期时间错开
- redis集群实现高可用
- 主从+哨兵
- redis 集群
- 开启redis持久化aof、rdb,尽快恢复集群数据
- 多缓存结合预防雪崩
- encache本地缓存+redis缓存
- 服务降级
- hystrix或者sentinel限流&降级
- 使用云服务redis
三、缓存穿透
-
是什么
-
请求去查询一条记录,先查redis无,后查mysql无,都查询不到该条记录,但是请求每次都会打到数据库上面去,导致后台数据库压力暴增,这种现象我们称为缓存穿透,这个redis就变成了一个摆设。
-
简单说就是,本来无一物,两库都没有。既不在Redis,也不在数据库,数据库存在被多次暴击风险
-
-
解决
-
缓存穿透最怕恶意攻击,使用空对象缓存、布隆过滤器可解决
-
空对象缓存或者缺省值
黑客或者恶意攻击
黑客会对你的系统进行攻击,拿一个不存在的id去查询数据,会产生大量的请求到数据库去查询。可能会导致你的数据库由于压力过大而宕掉。
-
key相同
第一个打到mysql,空对象缓存后,第二次就返回null或者默认值,避免mysql被打击,不用再查询数据库。
-
key不相同
由于存在空对象缓存和缓存回写,redis中的无关紧要的key也会越来越多,需要设置过期时间
-
-
使用google guava布隆过滤器
guava中布隆过滤器的实现比较权威,所以实际项目中可以直接使用guava布隆过滤器
案例:白名单过滤
-
四、缓存击穿
-
是什么
大量的请求同时查询一个key,并且这个key此时正好失效了,就会导致大量的请求到达数据库。
简单的说就是热点key突然失效,暴打mysql
-
危害
会造成某一时刻数据库请求过大,压力剧增
一般需要技术部门知道哪些是热点key,防止击穿
-
解决
缓存击穿,热点key失效,解决方法:互斥更新、随机退避、差异失效时间
失效原因:
- 时间到了自然清除,但还被访问到了
- 删除key的时候,突然被访问到了
解决方法:
-
差异失效时间,对于访问频繁的热点key,就不设置过期时间
-
互斥更新,采用双检加锁策略文章来源:https://www.toymoban.com/news/detail-662947.html
五、总结
文章来源地址https://www.toymoban.com/news/detail-662947.html
到了这里,关于07_缓存预热&缓存雪崩&缓存击穿&缓存穿透的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!