本文主要是介绍常见的缓存中间件缓存击穿、缓存穿透、缓存雪崩问题与解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
概述
面试中常常被问到 缓存击穿、缓存穿透、缓存雪崩 指什么以及对应的解决方案,下面进行详细总结:
缓存穿透
指查询一个不存在的数据,缓存中没有,数据库中也没有;
解决方案:
-
布隆过滤器,向布隆过滤器中添加一个元素 key 时,我们通过多个 hash 函数,算出对应的值,然后将这个值所在的方格置为 1。查询的时候也是计算 Hash 值,若有一个格子不为 1,那么说明元素肯定不在数组中。布隆过滤器可以判断某个数据一定不存在,但是无法判断一定存在。
-
对空结果进行缓存返回
缓存击穿
指查询一个热点 key 的时候,由于 key 过期导致查询走到数据库中,造成数据库的压力大。
解决方案:
- 互斥访问,拿不到锁的进行等待,等获取到锁时已有缓存
- 热点 Key 不过期
- 降级策略
- 热点 Key 放到不同的服务器上面
- 加入二级缓存,提前加载 key 到内存中
缓存雪崩
某一时刻,大规模的 key 失效,导致请求全部走到数据库中,造成数据库压力大。
解决方案:
- key 过期时间可以在原有时间上面增加一个随机值
- 限流
- 二级缓存
总结
注意上面对应缓存问题的解决方案,可以互用;比如缓存雪崩,也可以使用互斥访问、降级策略等办法减少对数据库的压力,从而缓解存在的问题。
不要陷入知识的陷阱中,遇到问题,找到合适的解决方案即可,上面方案仅做借鉴。
这篇关于常见的缓存中间件缓存击穿、缓存穿透、缓存雪崩问题与解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!