Redis的穿透和雪崩以及解决方案
1.缓存雪崩:
一瞬间大量流量把Redis和数据库全部打死,导致服务不可用而造成损失
缓存雪崩的事前事中事后的解决方案如下。
- 事前:redis 高可用,主从+哨兵,redis cluster,避免全盘崩溃。
- 事中:本地 ehcache 缓存 + hystrix 限流&降级,避免 MySQL 被打死。
- 事后:redis 持久化,一旦重启,自动从磁盘上加载数据,快速恢复缓存数据。
2.缓存击穿
一瞬间大量流量直接穿过Redis把数据库打死
解决方案:布隆过滤器/ehcache 缓存