Redis缓存穿透和雪崩
作者:哇塞大嘴好帥(哇塞大嘴好帅)
1.缓存穿透
请求数据会先去缓存种查询,如果缓存没有再去数据中查询,数据库也没有,这时候就会洪水攻击这时候就会出现问题
1.1解决方案
布隆过滤器
布隆过滤器是一种数据结构,对所有可能查询的参数以hash形式存储,在控制层高先进行校验,不符合直接丢弃,从而避免了对底层系统查询的压力
缓存空对象
当存储层不命中后,即使返回空对象也将其缓存起来,同时会设置一个过期时间,之后在访问这个数据将会从缓存获取,保护后端数据源。
出现的问题:
1.要建立很多空值的建
2.即使空值设置的过期时间,缓存层和存储层数据又会一段时间窗口的不一致,影响要求一致性的业务
2.缓存击穿
在同一时间有很大的并发去请求同一位置的数据,量太达缓存过期或者key失效,就会直接访问数据库。
2.1解决方案
设置缓存永久不过期
如果不过期一直缓存会浪费资源
加互诉锁
保证每个key设置同一时间只有一个线程可以访问
3.缓存雪崩
**缓存雪崩是指在一个时间都拿,缓存集中过期失效。Redis宕机。**比如停电了,机房着火了。扫地大妈给机房电源拔了