有没有遇到了击穿缓存层,好几个线程访问数据库。导致程序奔溃的事?
一直想过来总结下,总是拖着,今天就给整写了。
定义:
缓存穿透通常是带空key值,恶意攻击,欺骗缓存造成无限制访问数据库;
缓存并发通常是缓存key过期时,多请求查询数据库,回写缓存,导致性能降低
缓存雪崩通常缓存服务器重启或者大量缓存集中失效,致使数据库访问加大,甚至压垮数据库。
解决:
缓存穿透:可以对输入的参数进行过滤,把无效请求拦在外面。具体比如判断ID是否合法。
缓存并发:加锁。分布式锁,本地锁,软过期。这三种都可以。首推软过期。
缓存雪崩:通常的解决办法是对不同的数据使用不同的失效时间,就会避免缓存雪崩。
讲的是个大概的思路具体的解决办法网上都有代码可查。
继续阅读与本文标签相同的文章
上一篇 :
自动化日志收集及分析在支付宝 App 内的演进
下一篇 :
PHP实现线性表的顺序存储结构
-
Kubernetes监控实践(1):K8s的工作原理与监控实践
2026-05-18栏目: 教程
-
奇葩设计师贾伟打开你的想象力经济
2026-05-18栏目: 教程
-
如何组建网络空间安全大赛
2026-05-18栏目: 教程
-
Jmeter四大随机数(一):$__Random(,,)
2026-05-18栏目: 教程
-
从零开始入门 K8s| 阿里技术专家详解 K8s 核心概念
2026-05-18栏目: 教程
