缓存雪崩、缓存击穿、缓存穿透:
详细介绍看这篇文章,写得很好:
什么是缓存雪崩、缓存击穿、缓存穿透
下面是我自己总结的,比较简单清楚地展示了缓存雪崩、缓存击穿和缓存穿透的根本区别和相应的解决办法。强烈建议看完上述文章后再过一遍这个表,加深记忆!
失效key个数 | key是否有效(key原先是否存在) | 解决办法 | |
---|---|---|---|
缓存雪崩 | 大量key同时失效 | 存在 | 1、给key的失效时间加一个随机数,防止大量key同时失效; 2、采用熔断机制,设置流量阈值 3、Redis宕机导致大量key失效时,使用redis集群提高容灾能力 |
缓存击穿 | 少量key(热点)失效 | 存在 | 1、设置锁,互斥访问 2、对热点key设置永不失效 |
缓存穿透 | 可少可大 | 不存在 | 1、缓存中设置不存在key的value值为null 2、通过布隆过滤器过滤访问 3、对恶意的key值(非法参数、不可能存在的key值)直接禁止访问 |