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

面试官最爱问的Redis缓存三兄弟:雪崩、穿透、击穿,我用外卖订单场景给你讲明白

外卖系统高并发实战Redis缓存三兄弟的解决方案中午12点某外卖平台的订单量突然激增系统开始出现响应延迟。用户反复刷新页面却看到网络开小差的提示而商家后台则不断弹出订单查询失败的报警。这熟悉的场景背后往往隐藏着Redis缓存使用中的三大经典问题雪崩、穿透和击穿。作为后端开发者如果不能透彻理解这三种异常情况就像厨师不知道火候控制一样危险。1. 缓存雪崩当所有活动同时失效想象一下外卖平台正在举行全城五折日数万商家同时参与促销活动。技术团队为每个店铺的促销信息设置了缓存并统一设置为2小时过期。当缓存集体失效的那一刻数据库瞬间收到了超过平时50倍的查询请求——这就是典型的缓存雪崩。雪崩问题的核心在于大量缓存同时失效导致请求直接穿透到数据库。在外卖系统中这类问题常出现在店铺营业状态缓存所有店铺状态同时更新全局促销活动缓存区域运力配置缓存解决方案对比表方案类型具体实现适用场景优缺点过期时间随机化基础过期时间随机偏移量如300秒±随机60秒批量缓存初始化场景实现简单但无法应对缓存全量崩溃多级缓存LocalCacheRedisDB三级回源极端高并发场景架构复杂维护成本高热点数据永不过期异步线程定期更新缓存极热点数据如头部商家可能产生脏读需要版本控制// Spring Boot中实现随机过期时间的配置示例 Bean public RedisCacheManagerBuilderCustomizer redisCacheManagerBuilderCustomizer() { return (builder) - builder .withCacheConfiguration(shopStatus, RedisCacheConfiguration.defaultCacheConfig() .entryTtl(Duration.ofSeconds(300 new Random().nextInt(120)))); }在实际项目中我们采用了组合方案对普通店铺使用随机过期时间对头部Top100商家采用多级缓存策略。某次大促期间这种混合方案成功将数据库QPS从峰值2万稳定控制在5000以下。关键提示雪崩防护的重点不是完全避免缓存失效而是控制失效的节奏和影响范围。就像高峰期的地铁限流需要错峰而不是阻断。2. 缓存穿透恶意请求的完美风暴凌晨3点监控系统突然报警显示数据库CPU使用率达到100%。排查发现有大量请求在查询不存在的店铺IDshop_999999。这就是缓存穿透——查询根本不存在的数据导致每次请求都直达数据库。外卖系统中的典型穿透场景恶意爬虫遍历店铺ID用户输入非法ID尝试获取数据已下架商品被持续请求防御方案四重奏入口校验在Controller层对参数进行强校验GetMapping(/shops/{id}) public ResponseEntityShopInfo getShopInfo(PathVariable Min(1) Long id) { // 业务逻辑 }布隆过滤器使用RedisBloom模块预先存储所有合法ID# 使用Redisson实现的布隆过滤器 RBloomFilterLong bloomFilter redisson.getBloomFilter(shopIds); bloomFilter.tryInit(1000000L, 0.03); if(!bloomFilter.contains(shopId)) { return Result.error(店铺不存在); }空值缓存对不存在的key也进行短时间缓存SET shop:999999 NULL EX 60风控系统识别异常请求模式并自动封禁在某次安全审计中我们发现一个脚本正在以每秒200次的频率扫描店铺ID。通过部署布隆过滤器空值缓存组合方案成功将这类无效请求的数据库穿透率降低到0.1%以下。3. 缓存击穿爆款菜品的秒杀危机晚上6点某网红餐厅的招牌菜品突然被1万用户同时点击恰巧该菜品缓存刚刚过期。瞬间爆发的请求全部落到数据库这就是缓存击穿——单个热点key失效引发的系统风暴。外卖业务中的击穿高发区爆款菜品详情页限时秒杀活动头部商家主页互斥锁实现方案对比实现方式代码示例适用场景注意事项Redis SETNXSET lock_key 1 EX 10 NX简单分布式场景需处理锁续期问题Redisson锁RLock lock redisson.getLock();复杂分布式系统支持可重入、看门狗机制本地锁RedissynchronizedRedis混合架构要注意本地锁的范围public Shop getShopWithMutex(Long id) { String cacheKey shop: id; // 尝试从缓存获取 Shop shop redisTemplate.opsForValue().get(cacheKey); if (shop ! null) { return shop; } // 获取分布式锁 String lockKey lock:shop: id; try { boolean locked redisTemplate.opsForValue() .setIfAbsent(lockKey, 1, 30, TimeUnit.SECONDS); if (locked) { // 二次检查缓存 shop redisTemplate.opsForValue().get(cacheKey); if (shop ! null) { return shop; } // 查询数据库 shop shopMapper.selectById(id); redisTemplate.opsForValue().set(cacheKey, shop, 1, TimeUnit.HOURS); return shop; } else { // 未获取到锁短暂休眠后重试 Thread.sleep(100); return getShopWithMutex(id); } } finally { redisTemplate.delete(lockKey); } }在实战中我们发现单纯的互斥锁在高并发下会导致大量线程阻塞。最终方案是结合互斥锁与本地缓存将数据库查询QPS从峰值8000降至200左右。4. 复合防御外卖系统的缓存架构实践真实的业务场景往往同时存在雪崩、穿透和击穿风险。某外卖平台日均订单量突破300万时我们设计了多层次的防御体系缓存架构四层防护前端限流滑动窗口算法控制API调用频率limit_req_zone $binary_remote_addr zoneapi_limit:10m rate100r/s;中间层过滤布隆过滤器拦截非法ID空值缓存吸收无效请求热点识别自动预热缓存集群多AZ部署防止单点故障差异化过期策略熔断降级机制数据库保护读写分离连接池限流慢查询优化监控指标看板指标名称预警阈值监控频率应对措施缓存命中率90%每分钟检查热点key分布数据库QPS5000每秒触发自动限流慢查询比例1%每5分钟SQL优化缓存穿透率5%实时调整布隆过滤器这套体系在去年双11期间经受住了考验当时最高并发达到每秒3万订单而数据库负载始终保持在安全水位。一个有趣的发现约70%的缓存问题实际上源于不当的键设计比如没有区分冷热数据。

相关文章:

面试官最爱问的Redis缓存三兄弟:雪崩、穿透、击穿,我用外卖订单场景给你讲明白

外卖系统高并发实战:Redis缓存三兄弟的解决方案 中午12点,某外卖平台的订单量突然激增,系统开始出现响应延迟。用户反复刷新页面却看到"网络开小差"的提示,而商家后台则不断弹出"订单查询失败"的报警。这熟悉…...

Proteus仿真+C51汇编:从零搭建单片机最小系统(新手实践)

1. 准备工作:软件安装与环境配置 第一次接触单片机开发的朋友可能会被各种专业软件吓到,但其实只要跟着步骤一步步来,很快就能上手。我刚开始学51单片机的时候,光是装软件就折腾了半天,现在把这些经验都总结给你。 首先…...

Artifactory OSS实战:不止于搭建,教你用Gradle插件一键发布Android AAR到私有仓库

Artifactory OSS实战:Gradle插件自动化发布Android AAR全流程指南 当团队开始采用组件化架构时,如何高效管理内部模块的二进制依赖成为关键痛点。想象这样一个场景:你刚完成公司支付SDK 1.0版本的开发,现在需要让其他五个业务团队…...

树莓派5B到手后,别急着点亮LED,先搞定这三件小事(VSCode远程+换源+SSH密钥)

树莓派5B开箱必做三件事:高效开发环境搭建指南 刚拿到树莓派5B的兴奋感,就像孩子拿到新玩具一样迫不及待想点亮第一个LED。但别急,工欲善其事必先利其器——这三个看似简单的配置步骤,能让你的开发效率提升300%。我曾在凌晨三点调…...

MAA自动化助手:明日方舟玩家的终极解放方案

MAA自动化助手:明日方舟玩家的终极解放方案 【免费下载链接】MaaAssistantArknights 《明日方舟》小助手,全日常一键长草!| A one-click tool for the daily tasks of Arknights, supporting all clients. 项目地址: https://gitcode.com/G…...

CentOS 7.6离线安装Perl全攻略:27个核心依赖包清单与一键安装命令

CentOS 7.6离线安装Perl全流程实战指南 在金融、军工等对网络安全要求极高的行业场景中,服务器通常运行在完全隔离的内网环境。上周为某银行数据中心部署日志分析系统时,就遇到了必须在无外网连接的CentOS 7.6服务器上安装Perl运行环境的挑战。与在线安…...

Linux 误删文件自救指南:从绝望到恢复的全过程

1. 当误删发生时:从恐慌到冷静的技术自救 "手滑误删"可能是每个Linux用户最不愿面对的噩梦。上周我就亲身经历了这样的惊魂时刻——在VSCode里批量删除临时文件时,不小心把写了三天的Nginx配置也送进了黑洞。那一瞬间,后背发凉、心…...

【凌晨2点被攻破的AI生成接口】:一个未校验的正则表达式如何引发RCE——生成代码安全检查黄金48小时响应协议

第一章:智能代码生成代码安全性检查 2026奇点智能技术大会(https://ml-summit.org) 智能代码生成工具(如Copilot、CodeWhisperer、Tabnine)在提升开发效率的同时,可能引入未经验证的安全隐患——包括硬编码密钥、不安全的反序列化…...

Qt桌面应用实战:集成YOLOv8 ONNX模型,实现摄像头/视频文件的实时目标检测与界面显示

Qt桌面应用实战:集成YOLOv8 ONNX模型实现高效目标检测 在智能视觉应用开发领域,如何将前沿的深度学习模型无缝集成到成熟的桌面框架中,是许多开发者面临的现实挑战。本文将深入探讨基于Qt框架构建一个支持实时目标检测的桌面应用,…...

AI设计:核心方法、工具选型与商业落地实操指南

近两年AI技术在设计领域的渗透速度远超行业预期,很多设计师对AI的认知还停留在生成零散创意素材的阶段,不少设计师担心被AI替代,也有不少设计师把AI当成玩具,没有挖掘到实际的商用价值。据国内设计行业协会2024年调研数据显示&…...

MySQL错误日志里Aborted connection刷屏?别慌,5分钟定位是程序Bug还是配置问题

MySQL错误日志Aborted connection暴增?三步精准定位问题根源 凌晨三点,手机突然被监控告警轰炸——MySQL错误日志里Aborted connection警告每分钟新增上百条。作为经历过多次类似场景的老DBA,我深知这种问题绝不能简单调整wait_timeout了事。…...

WPF Halcon混合开发避坑指南:解决HSmartWindowControlWPF上叠加UI控件的焦点与事件冲突

WPF Halcon混合开发实战:解决HSmartWindowControlWPF叠加UI的交互冲突 在工业视觉应用开发中,WPF与Halcon的混合开发模式已经成为主流选择。HSmartWindowControlWPF作为Halcon.NET的核心显示控件,其与WPF原生UI的深度集成却常常让开发者陷入各…...

利用Knockd与iptables打造隐形SSH通道,黑客无从下手

1. 为什么你的SSH端口总被黑客盯上? 每次查看服务器日志,总能看到一堆陌生的IP地址在疯狂扫描你的22端口,这种感觉就像家门口整天有人转悠,让人浑身不自在。传统的SSH防护手段,比如修改默认端口或者设置fail2ban&#…...

Excalidraw手绘白板:5分钟上手的终极协作绘图指南

Excalidraw手绘白板:5分钟上手的终极协作绘图指南 【免费下载链接】excalidraw Virtual whiteboard for sketching hand-drawn like diagrams 项目地址: https://gitcode.com/GitHub_Trending/ex/excalidraw 想要一款既专业又轻松的手绘风格白板工具吗&#…...

OpenEuler部署Chrony:从零构建高精度私有时间同步网络

1. 为什么企业需要私有时间同步网络 想象一下公司里所有电脑和服务器的时间都不一致会怎样?打卡系统显示9:00而邮件服务器记录8:55,数据库集群因为时间差导致事务冲突,监控系统告警时间错乱...这些看似小问题可能引发连锁反应。去年我们团队…...

ElasticDump 离线部署实战:从打包到验证的完整指南

1. 为什么需要ElasticDump离线部署? 在企业生产环境中,数据安全永远是第一位的。很多金融、政务类企业的核心业务系统都部署在物理隔离网络中,这种环境下服务器根本无法连接外网。但数据迁移需求又真实存在——比如要把测试环境的Elasticsear…...

给OpenWrt写个‘Hello World’:手把手教你从C代码到.ipk安装包(附完整Makefile)

从零构建OpenWrt软件包:Hello World实战指南 第一次为OpenWrt开发软件包时,那种既兴奋又困惑的感觉至今难忘。看着路由器上运行着自己编写的程序,仿佛打开了嵌入式开发的新世界。本文将带你完整走一遍这个神奇的过程——从几行简单的C代码开始…...

Axure中文界面完整指南:3分钟彻底告别英文菜单困扰

Axure中文界面完整指南:3分钟彻底告别英文菜单困扰 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在为Axure RP的…...

CMake配置OpenCV时遭遇‘No such file or directory‘:从find_package到target_link_libraries的完整避坑指南

1. 为什么CMake找不到OpenCV头文件? 第一次用CMake配置OpenCV时,看到fatal error: opencv2/opencv.hpp: No such file or directory这个报错,我差点把键盘摔了。明明已经用find_package(OpenCV REQUIRED)找到了OpenCV,为什么编译器…...

企业流程异常处理自动化落地,预警处置全流程实现方案:2026企业“数字免疫系统”构建指南

站在2026年的技术节点回望,企业数字化转型已从“业务上云”全面转向“智能自治”。在高度动态的市场环境下,生产中断、供应链波动、IT系统故障或合规性风险等流程异常,已成为衡量企业韧性的“试金石”。传统的被动响应模式正迅速被预警、诊断…...

不止于安装:用IGH EtherCAT主站源码编译,深入理解Linux内核模块与实时性配置

不止于安装:用IGH EtherCAT主站源码编译,深入理解Linux内核模块与实时性配置 在工业自动化领域,EtherCAT凭借其卓越的实时性能和高效的通信机制,已成为现代工业控制系统的重要支柱。而作为EtherCAT网络的核心,主站系统…...

开源实战:用安卓App与微信小程序双端联动,远程操控Arduino智能设备

1. 从零搭建智能灯光控制系统 想象一下这样的场景:下班路上用手机提前打开家里的氛围灯,朋友来访时让他们用微信小程序调节灯光亮度,所有操作都通过你亲手搭建的系统完成。这就是我们要实现的ArduinoESP8266-01双端控制方案,一个…...

多特征融合下的随机森林遥感影像智能解译

1. 多特征融合为什么能提升遥感影像解译效果 我第一次接触遥感影像分类时,发现单纯用原始波段数据效果总是不理想。后来才明白,就像做菜需要各种调料搭配一样,遥感影像解译也需要多种特征"调味"。多特征融合的核心思路,…...

团队协作:pre-commit 配置与实战进阶指南

1. 为什么团队需要 pre-commit 自动化检查 第一次在团队推行 pre-commit 时,我遇到了这样的场景:新来的前端开发同事提交了一段 JavaScript 代码,由于缩进风格不一致,导致代码审查时花了20分钟讨论该用 tab 还是空格。这种事情每周…...

别再手动上传脚本了!手把手教你配置Jmeter分布式压测(Linux Master + Windows Slave实战)

别再手动上传脚本了!手把手教你配置Jmeter分布式压测(Linux Master Windows Slave实战) 分布式压测是性能测试工程师进阶的必经之路,但传统方式中频繁上传脚本、下载大体积结果文件的痛点,让很多团队望而却步。本文将…...

如何高效获取抖音无水印视频:douyin-downloader 完整实战指南

如何高效获取抖音无水印视频:douyin-downloader 完整实战指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallbac…...

从TensorFlow 1到2:BigEarthNet-MM数据集官方划分代码的现代化改造与避坑指南

1. 从TensorFlow 1到2的迁移挑战 BigEarthNet-MM数据集是遥感图像分析领域的重要资源,但官方提供的19类划分代码基于TensorFlow 1.x版本编写。随着TensorFlow 2.x的普及,许多开发者在使用这些代码时遇到了兼容性问题。我最近在实际项目中完成了这个迁移…...

AutoGen Studio一站式部署指南:从Conda环境到Web界面

1. 环境隔离:用Conda打造专属Python沙盒 第一次接触AutoGen Studio时,我最头疼的就是各种Python包版本冲突。比如上周帮同事调试时,他的TensorFlow死活装不上,最后发现是系统自带的Python 3.7不兼容。这种问题用Conda就能完美解决…...

拆解智能车‘心脏’:深度剖析DRV8701E+H桥如何实现电机的精准控制与高效保护

智能车动力心脏解剖:DRV8701E与H桥协同设计中的精密控制艺术 当智能车在赛道上以毫米级精度漂移过弯时,背后是电机驱动系统每秒数千次的电流调节。这场精密舞蹈的核心指挥者,正是DRV8701E这颗高度集成的H桥栅极驱动器。不同于普通驱动芯片的粗…...

从零开始学ABB机器人RAPID编程:外部IO信号中断的5个常见误区与解决方案

从零开始学ABB机器人RAPID编程:外部IO信号中断的5个常见误区与解决方案 在工业自动化领域,ABB机器人凭借其稳定性和灵活性广受青睐,而RAPID编程语言则是操控这些工业巨臂的核心工具。对于刚接触ABB机器人编程的工程师来说,外部IO信…...