缓存穿透
缓存穿透就是指客户端请求的数据在缓存中和数据库中都不存在,这样缓存永远不会生效,这些请求都会打到数据库。
解决方案:
- 缓存空对象
优点:实现简单,维护方便。
缺点:1.额外的内存消耗
2.可能造成短期的不一致 - 布隆过滤
优点:内存占用较少,没有多余key
缺点:1.实现复杂
2.存在误判的可能
缓存雪崩
缓存雪崩是指在同一时间段大量的缓存key同时失效或者Redis服务宕机,导致大量的请求到达数据库,带来巨大压力
解决方案:
- 给不同得key的TTL添加随机值
- 利用Redis集群提高服务的可用性
- 给缓存业务添加降级限流策略
- 给业务添加多级缓存
缓存击穿
缓存击穿问题也叫热点key问题,就是一个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击。
解决方案:
- 互斥锁
优点:1.没有额外的内存消耗
2.保证一致性
3.实现简单
缺点:1.线程需要等待,性能受影响
2.可能有死锁的风险 - 逻辑过期
优点:线程无需等待,性能较好。
缺点:1.不保证一致性
2.有额外内存小号
3.实现复杂