当前位置: 首页 > news >正文

Redis 缓存穿透、击穿、雪崩,我花了 3 年才分清它们的区别

面试时被问到"Redis 缓存穿透、击穿、雪崩有什么区别",我支支吾吾答不上来。工作三年后,终于在实际项目中把这三个概念搞清楚了。

不是我不爱学习,是这三个名字太像了,网上很多文章也讲混了。我用自己的踩坑经历,帮你彻底分清。

缓存穿透:查询一个不存在的数据

场景:用户查询一个数据库里根本没有的 key,比如 id=-1 的商品。

问题:每次查询都会穿透缓存,直接打到数据库。如果恶意攻击者构造大量不存在的 key,数据库会扛不住。

我的踩坑:早期项目没做校验,有人用脚本批量请求不存在的商品 ID,数据库 CPU 飙到 90%。

解决方案:布隆过滤器,或者缓存空值(设置较短的过期时间,比如 5 分钟)。

缓存击穿:一个热点 key 过期了

场景:某个 key 访问量极高,比如首页的商品列表。这个 key 过期的一瞬间,大量请求同时打到数据库。

问题:不是查询不存在的数据,是查询存在的数据,但缓存刚好失效。

我的踩坑:双十一活动页,缓存设置了 10 分钟过期。过期那一刻,数据库直接挂了。

解决方案:互斥锁(只有一个线程去查数据库,其他线程等待),或者逻辑过期(不设置 TTL,用逻辑时间判断)。

缓存雪崩:大量 key 同时过期

场景:缓存重启、或者批量设置了相同的过期时间,导致大量 key 在同一时间失效。

问题:和击穿类似,但规模更大。不是单个 key,是成片 key 同时失效。

我的踩坑:项目上线时,为了"预热缓存",一次性加载了 10 万个 key,全部设置了 1 小时过期。1 小时后,数据库被瞬间打爆。

解决方案:过期时间加随机偏移(比如 1 小时 ± 10 分钟),或者多级缓存(本地缓存 + Redis)。

一句话总结

  • 穿透:查不存在的数据(恶意攻击)

  • 击穿:热点 key 刚好过期(瞬时高并发)

  • 雪崩:大量 key 同时过期(系统性风险)

面试时的回答技巧

不要背定义,讲场景。面试官想听的是:你在什么情况下遇到过,怎么解决的。

我现在的回答结构是:场景描述 → 问题现象 → 解决方案 → 后续预防。

你们在实际项目中遇到过哪种?

我查了下,很多公司的缓存策略其实是"混着用"的,没有严格区分这三种情况。是不是只有大厂才会精细化处理?

http://www.jsqmd.com/news/1081829/

相关文章:

  • FMA音乐分析数据集架构设计:企业级音乐信息检索解决方案
  • 3分钟快速搭建个人专属Web邮件系统:Roundcube Mail终极指南
  • ASP.NET Web Service SQL注入漏洞实战:从环境搭建到自动化利用与修复
  • 【JAVA毕设源码分享】基于SpringBoot的在线骑行网站的设计与实现(程序+文档+代码讲解+一条龙定制)
  • GARbro终极指南:快速掌握视觉小说资源提取的完整方案
  • 开源数据恢复实战:高效压缩包密码破解方案解析
  • 【Springboot毕设全套源码+文档】基于SpringBoot的在线骑行网站的设计与实现(丰富项目+远程调试+讲解+定制)
  • 不小心删掉微信聊天?这份自救指南收好
  • GPT与人工协同文本标注的工业级实践指南
  • 【独家首发】全球TOP 10金融客户vSphere迁移实录:为什么83%最终选择Proxmox VE+ZFS+CT集群?
  • 2026年准备创业做品牌,该如何选择靠谱的广州商标设计公司
  • FFmpeg 技术手册(完整版)
  • ThreadLocal 我看了好几遍才看懂,原来关键在引用上
  • Adobe-GenP 3.0终极指南:如何免费解锁Adobe全家桶所有功能
  • 基于SMAC与HCS08的嵌入式无线开发实战:从环境搭建到产品优化
  • 打破苹果硬件限制:OpenCore Legacy Patcher让老旧Mac重获新生
  • VMware Player Pro停更预警!:2024年起仅限个人非商业使用——Workstation Pro成唯一合规生产环境选择
  • 基于MPC5744P的功能安全评估套件:硬件架构与软件开发实战
  • 多核DSP性能分析实战:硬件跟踪点与计数器点精准定位瓶颈
  • N_m3u8DL-CLI-SimpleG:图形化界面让M3U8视频下载不再困难
  • 5步实战:开源中文字体从痛点分析到完美应用的完整解决方案
  • FFmpegGUI:告别命令行恐惧,3步实现专业级视频处理
  • SCF5250 IEC958接口CD子码解析实战:从寄存器操作到稳定数据流处理
  • APMCM亚太杯数学建模竞赛:从零到一掌握论文写作与团队协作全攻略
  • 嵌入式技术趋势
  • 前端工具链实践
  • 【VMware Workstation Pro 17 vs VirtualBox 7.0】:内存占用差3.8倍、快照启动慢62%、USB 3.0兼容率仅41%…这些硬伤你还在忍?
  • 别让帮助中心变成摆设:用AI知识管理构建产品在线帮助中心的5个关键步骤
  • 为什么数据安全评估师突然火了?我扒了今年几十个岗位JD发现...
  • 线下会场网络差?这款APP离线录音不遗漏任何内容