1、缓存穿透
问题描述:访问数据库中不存在的数据,也不会写入缓存,导致每次访问都是直接请求数据库
解决方法:a.返回null值,简单,但是当有大量的不存在的数据时,消耗内存,而且会导致数据不一致
b.布隆过滤器,内存占用较少,没有多余key;但是实现复杂,存在误判。
2、缓存击穿
问题描述:给某个key设置了过期时间,当key过期的时候,恰好这时间点对这个key有大量的并发请求过来,这些并发的请求可能会瞬间把DB压垮
解决办法:a、互斥锁,强一致,性能差
b.逻辑过期,高可用,性能优,不能保证主句绝对一致
3、缓存雪崩
问题描述:同一时间段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。
解决办法:a.给不同的key的TTL添加随机值
b.利用Redis集群提高服务的可用性
c.给缓存业务添加降级限流策略
d.给业务添加多级缓存
文章探讨了三种缓存问题:缓存穿透可通过返回null或使用布隆过滤器来解决,缓存击穿可采用互斥锁或逻辑过期策略,而缓存雪崩则建议用随机TTL、Redis集群及降级限流来应对。

被折叠的 条评论
为什么被折叠?



