缓存穿透、缓存击穿、缓存雪崩详解以及解决方案
一。缓存穿透
查询一个不存在的数据,mysql查询不到数据也不会直接写入缓存,就会导致每次请求都查数据库
 方案一:
 
方案二:
 
二。缓存击穿
给某一个key设置了过期时间,当key过期的时候,恰好这时间点对这个key有大量的并发请求过来,这些并发的请求可能会瞬间把DB压垮
 
方案一:
 互斥锁:保证数据的 强一致性 性能差
 
方案二:
 逻辑过期:高可用 性能优
 
三。缓存雪崩
缓存雪崩是指在同一时段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。
 
方案一
 给不同的Key的TTL添加随机值
 方案二
 利用Redis集群提高服务的可用性 —— 哨兵模式、集群模式
 方案三
 给缓存业务添加降级限流策略 —— ngxin或spring cloud gateway
 方案四
 给业务添加多级缓存 —— Guava或Caffeine



















