【缓存】缓存击穿、缓存穿透、缓存雪崩

缓存的作用

缓存的主要目的是减轻数据库的压力。

当有请求来时,先去查找缓存,缓存有数据则直接返回;

缓存没有数据,再去数据库请求,将数据写入缓存再返回;

如果数据库中也没有数据,那可能就是程序有问题了,返回错误信息。

缓存穿透

如果有攻击者伪造了一个请求,而且请求的数据再缓存中找不到,那么每次请求,都会从数据库中查找。缓存就像不存在一样,这种现象就是缓存穿透。如果攻击者利用这样的漏洞,发起多次请求,给数据库就会造成巨大压力。

解决方案:

1)对请求进行校验,比如请求的数据,缓存中肯定没有,并且数据库中也肯定没有的情况,直接拦截过滤掉。

2)缓存空值。缓存中没找到请求的数据,数据库中也没有请求的数据,那么把这个请求数据保存在缓存里,但是置为空。下次请求相同的数据,判断是否为空值,如果是空值,返回错误信息;如果不为空值,返回请求数据即可。

3)如果数据量比较小,可以全部放在缓存中,有请求的数据就返回,没有就返回空。

4)使用布隆过滤器可以过滤掉大量恶意请求不存在数据的情况。(待补充)但是布隆过滤器会来带两个新的问题:1)存在误杀的情况;2)如果数据有变化,需要实时同步到布隆过滤器。

缓存击穿

一般缓存的数据都有有效期,当某个数据有效期过了,对该数据的所有请求统统走向了数据库,数据库由于突然大量的请求访问可能就会崩掉了,这就是缓存击穿。

解决方案:

1)当缓存数据即将失效前重新设置有效期,比如数据30分钟后失效,在20分钟的时候重新设置数据有效期为30分钟。

缓存雪崩

缓存雪崩是缓存击穿的升级版。当有多个缓存数据同时失效了,大批量的请求都走向了数据库访问,数据库压力骤增很有可能崩掉,这就是缓存雪崩。

解决方案:

1)不同的缓存数据在过期时间的基础上添加1~60秒的随机时间,防止大批量的数据同时失效,可以有效减轻缓存雪崩。

2)分布式高可用,如redis可以设置哨兵,关注服务器的情况,如果某一台服务器因为缓存雪崩导致不可用了,立马调度另一台服务器顶上。

相关推荐
知我Deja_Vu8 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存
没有bug.的程序员9 天前
电商秒杀系统深度进阶:高并发流量建模、库存零超卖内核与 Redis+MQ 闭环
数据库·redis·缓存·高并发·电商秒杀·流量建模·库存零超卖
troublea9 天前
ThinkPHP3.x高效学习指南
mysql·nginx·缓存
troublea9 天前
ThinkPHP6快速入门指南
数据库·mysql·缓存
Emotional。9 天前
AI Agent 性能优化和成本控制
人工智能·深度学习·机器学习·缓存·性能优化
jnrjian9 天前
Oracle 共享池 库缓存下的 Library Cache Lock
数据库·缓存·oracle
Anastasiozzzz9 天前
阿亮随手记:MySQL移除查询缓存、子查询优化深分页、自增主键溢出、索引失效
数据库·mysql·缓存
難釋懷9 天前
Redis消息队列-基于Stream的消息队列-消费者组
数据库·redis·缓存
難釋懷10 天前
Redis消息队列-基于Stream的消息队列
数据库·redis·缓存
troublea10 天前
Laravel 8.x新特性全解析
数据库·mysql·缓存