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

[Redis小技巧20]先删缓存还是先更新数据库?一文厘清 Redis 缓存一致性难题

在现代分布式系统中Redis 几乎已成为缓存层的“标配”。然而缓存与数据库之间的一致性问题始终是高并发场景下的“阿喀琉斯之踵”。一、为什么缓存一致性如此棘手缓存一致性问题的本质源于写操作在缓存与数据库之间的非原子性。当多个线程/服务同时读写时可能出现以下典型异常脏读读到旧缓存数据数据库已更新缓存未失效幻读缓存刚被删除另一个请求回种了旧值雪崩写入缓存失效瞬间大量请求穿透到 DB这些问题在秒杀、订单、库存等强一致性场景中尤为致命。二、主流缓存一致性方案详解1. Cache-Aside缓存分离模式 —— 行业默认方案这是最广泛采用的模式其读写流程如下读先查缓存 → 未命中则查 DB → 回填缓存写先更新 DB → 再删除缓存注意不是更新缓存优势简单、通用、避免缓存与 DB 写放大风险若“删缓存”失败将导致长时间不一致Cache-Aside 写流程关键点先更新 DB再删缓存。若反过来先删缓存再更新 DB在并发场景下极易出现“旧值回种”问题。2. “先删缓存再更新 DB” —— 为何是反模式假设有两个并发请求请求 A先删缓存请求 B读缓存miss→ 读 DB旧值→ 回种缓存请求 A更新 DB新值结果缓存中存的是旧值DB 是新值 → 不一致此方案在高并发下几乎必然失败强烈不推荐。3. 双删Double Delete策略为缓解“旧值回种”可在写操作中执行两次删除1. 删除缓存 2. 更新数据库 3. 延迟 N 毫秒后再次删除缓存第二次删除旨在清除步骤 2 期间可能被并发读请求回种的旧值。优点比单删更可靠缺点引入延迟、仍不能 100% 保证一致若第二次删失败或延迟不足双删失败案例展示1场景设定缓存键user:1001初始值{name: Alice, balance: 100}有两个并发操作同时发生写请求 W将余额更新为 200使用“双删”策略读请求 R在 W 执行过程中发起读取2详细时序展示“双删”失败的情况时间点操作状态T0W 开始第一次删除缓存(DEL user:1001)缓存为空T1R 发起读缓存 → miss—T2R 继续读数据库 → 得到旧值balance100DB 尚未更新T3W 继续更新数据库 →balance200DB 已更新T4R 继续将旧值balance100回种到缓存❌ 缓存被污染T5W 等待 N 毫秒比如 500ms后第二次删除缓存缓存再次被清空T6另一个读请求 R2缓存 miss → 读 DB → 得到200→ 回种正确值✅ 恢复正常问题出在哪里在T4 到 T5 之间缓存中存储的是错误的旧值100。如果在这段时间内有其他读请求比如 T4.5它们会读到脏数据。更糟的是如果第二次删除因网络超时、Redis 故障或程序异常而失败这个错误值可能长期驻留缓存3极端但真实的失败案例假设系统延迟波动大如 GC 停顿、网络抖动设置的“N 500ms”可能不够数据库主从同步延迟 800ms某个读请求从从库读到了旧值因为主从未同步完成它在 T4 回种了旧值而你的双删只等了 500ms第二次删除发生在主从同步完成前此时Redis缓存读到的依然是旧数据结果缓存长期不一致4如何缓解——但无法根治增大延迟时间 N如 1–2 秒→ 但牺牲响应速度用户体验下降第二次删除失败时重试如最多 3 次→ 增加复杂度结合 Binlog 监听如用 Canal自动失效缓存 → 转向更可靠的“订阅变更”模式但请注意只要删除操作是“尽力而为”best-effort就无法提供强一致性保证。4. 延时双删Delayed Double Delete这是双删的增强版通常配合消息队列实现第一次删缓存同步更新 DB发送延迟消息如 RabbitMQ / RocketMQ 延迟队列消费者在 1–2 秒后执行第二次删除优势解耦、可重试、避免阻塞主流程成本需引入 MQ系统复杂度上升5. 其他方案简述方案原理适用场景一致性强度Read/Write Through缓存层代理所有读写自动同步 DB封闭系统、中间件可控强Write Behind Caching先写缓存异步批量刷 DB日志、监控等容忍丢失场景弱版本号/逻辑时钟缓存与 DB 带版本读时校验极高一致性要求如金融强注Redis 本身不支持 Write Through需应用层或代理层实现如 Twemproxy 自定义逻辑。三、方案对比总表方案是否推荐并发安全性实现复杂度最终一致性典型应用场景先删缓存后更新 DB❌ 否低低❌ 差—Cache-Aside删缓存更新DB✅ 是中低✅ 可接受通用 Web 应用双删⚠️ 谨慎中高中✅ 较好订单、库存延时双删✅ 推荐高并发高高✅ 优电商、支付Read/Write Through✅若架构支持高高✅ 强金融核心系统四、高频面试题Q1为什么 Cache-Aside 模式要“先更新 DB再删缓存”答若先删缓存DB 更新前若有并发读请求会将旧值重新加载到缓存导致后续读取到脏数据。先更新 DB 可确保即使缓存 miss读到的也是最新值。Q2双删一定能解决一致性问题吗答不能 100% 保证。若第二次删除失败或延迟时间不足以覆盖所有并发读仍可能不一致。需配合重试、告警、监控机制。Q3如何监控缓存一致性问题答可通过以下方式记录缓存命中率突降对比 DB 与缓存的关键字段抽样校验使用 Redis 的MONITOR仅调试或审计日志在业务层埋点记录“缓存版本 vs DB 版本”Q4能否用 Redis 事务MULTI/EXEC保证一致性答不能。Redis 事务不支持回滚且无法跨 DB 与缓存原子操作。缓存一致性本质是分布式事务问题需更高层协调。

相关文章:

[Redis小技巧20]先删缓存还是先更新数据库?一文厘清 Redis 缓存一致性难题

在现代分布式系统中,Redis 几乎已成为缓存层的“标配”。然而,缓存与数据库之间的一致性问题,始终是高并发场景下的“阿喀琉斯之踵”。 一、为什么缓存一致性如此棘手? 缓存一致性问题的本质,源于写操作在缓存与数据库…...

Qwen3-Reranker-8B部署教程:Nginx反向代理+HTTPS保护Gradio WebUI

Qwen3-Reranker-8B部署教程:Nginx反向代理HTTPS保护Gradio WebUI 1. 引言:为什么需要安全部署? 当你成功部署了强大的Qwen3-Reranker-8B模型后,下一个重要问题就是如何安全地对外提供服务。直接暴露Gradio WebUI存在安全风险&am…...

C++ 避坑指南:解决 VS2019 E1696 源文件缺失与 MSB803 SDK 定位难题

1. 问题重现:当VS2019突然拒绝编译Hello World时 那天我正打算写个简单的C Hello World程序测试环境,按下F5的瞬间,屏幕上突然爆出400多个错误。最显眼的是E1696"无法打开源文件"和MSB803"找不到Windows SDK"的报错——这…...

Local SDXL-Turbo环境部署:512x512分辨率下的低延迟图像生成实践

Local SDXL-Turbo环境部署:512x512分辨率下的低延迟图像生成实践 重要提示:本文介绍的SDXL-Turbo模型仅支持英文提示词,默认输出分辨率为512x512,专为实时交互场景优化。 1. 环境准备与快速部署 1.1 系统要求与前置准备 在开始部…...

三相10kW光伏并网逆变器代码功能说明

三相10Kw光伏并网逆变器。包含全套理图/PCB/源代码一、概述 本文档详细解读基于TI F28379D DSP芯片的三相10kW光伏并网逆变器代码系统。该代码采用模块化设计,涵盖核心控制、硬件抽象、参数配置、驱动适配等多个功能层级,支持交流开环、电流环独立逆变、…...

RAG 完全图解:让 AI 不再“胡说八道“的核心技术

你让 AI 帮你查某款产品的售后政策,它给你列了一套看起来很专业的条款——但这些条款根本不存在。你让它总结一份技术文档的要点,它说得头头是道,可有一半内容是它自己编的。这不是 AI 变笨了,而是它根本"不知道"这些专…...

命题逻辑中的对偶原理:为什么它与德摩根律如此相似?

命题逻辑中的对偶原理:为什么它与德摩根律如此相似? 在数理逻辑的迷宫中,对偶原理与德摩根律如同两枚相互映照的棱镜,折射出命题逻辑的深层对称性。这种相似性绝非偶然——当我们将真值表翻转、将联结词置换时,隐藏在形…...

很多人不知道这个职业,应届生起薪破万、缺口超300万!

当学历内卷与岗位内卷成为压在年轻人身上的两座大山,一条鲜为人知的黄金赛道正在悄然敞开——网络安全工程师。这里不看你的毕业院校排名,不要求5年工作经验起步,甚至零基础3-5个月集训即可上岗,应届生起薪轻松破万! …...

归并排序实战:如何用分治思想高效计算逆序对(附Python代码)

归并排序实战:如何用分治思想高效计算逆序对(附Python代码) 在金融风控系统中,我们常需要评估交易数据的异常波动;在推荐算法里,用户行为序列的混乱程度直接影响推荐效果。这些场景背后都藏着一个关键指标—…...

Java桌面开发新姿势:用JCEF116.0.19内嵌Chrome内核实现混合开发(避坑指南)

Java桌面开发新姿势:用JCEF116.0.19内嵌Chrome内核实现混合开发(避坑指南) 在数字化转型浪潮中,企业级应用对跨平台、高交互界面的需求激增。传统Java桌面开发受限于AWT/Swing的陈旧架构,而Electron等方案又存在内存占…...

QLDependency:彻底解决青龙面板依赖配置难题的革新工具

QLDependency:彻底解决青龙面板依赖配置难题的革新工具 【免费下载链接】QLDependency 青龙面板全依赖一键安装脚本 / Qinglong Pannel Dependency Install Scripts. 项目地址: https://gitcode.com/gh_mirrors/ql/QLDependency QLDependency是一款专为青龙面…...

C#源码解析:欧姆龙NX1P通讯DEMO的CIP通讯实现

C#编写CIP通讯源码,欧姆龙NX1P通讯DEMO一、概述 本代码是基于C#语言开发的CIP(Common Industrial Protocol)通讯Demo程序,专门用于与欧姆龙NX1P2系列PLC进行工业通讯交互。程序采用.NET Framework 4.8框架开发,通过TCP…...

AI绘画新手入门:基于Anything V5的Web服务快速搭建指南

AI绘画新手入门:基于Anything V5的Web服务快速搭建指南 1. 准备工作与环境搭建 1.1 硬件与系统要求 在开始之前,请确保您的设备满足以下基本要求: 操作系统:Linux(推荐Ubuntu 20.04/22.04)GPU&#xff…...

收藏!大厂AI Agent开发岗位解析+小白友好型学习路线(程序员必看)

在AI技术迭代速度日益加快的当下,AI Agent(智能体)已然成为互联网大厂布局的核心方向,成为行业新风口。从阿里巴巴、字节跳动、腾讯等大厂最新校招JD中不难发现,AI Agent开发相关人才的缺口正持续扩大,薪资…...

高频面试题:口径变了,历史数据断层如何处理?

这道题是数据岗面试的核心高频题,尤其贴合当下口径精细化迭代的主流趋势——新口径要么是旧口径新增过滤规则、剔除无效数据,要么是拓展数据源、补充细分维度,绝非单纯的逻辑推翻。作答核心绝非粗暴刷数,而是平滑过渡、权责清晰、数据可追溯、可信度不打折,全程围绕“精细…...

饥荒云服保姆级搭建教程,一键部署专属于你的饥荒世界,手把手教你五分钟完成搭建过程!!

《饥荒联机版》(Dont Starve Together)是一款经典的生存沙盒游戏,与朋友一起在荒野中求生、对抗怪物、探索世界是游戏的乐趣所在。但官方服务器有时延迟高、不稳定,搭建自己的私人服务器可以让你和好友拥有专属的、低延迟的游戏环…...

基于主从博弈的动态定价策略与电动汽车充电管理优化在智能小区的应用研究

基于主从博弈的智能小区代理商定价策略及电动汽车充电管理 关键词:电动汽车 主从博弈 动态定价 智能小区 充放电优化 参考文档:《基于主从博弈的智能小区代理商定价策略及电动汽车充电管理》基本复现 仿真平台:MATLABCPLEX/gurobi平台 优势…...

TFT时间序列预测实战:用Python从零搭建电力需求预测模型(附完整代码)

TFT时间序列预测实战:用Python从零搭建电力需求预测模型(附完整代码) 电力需求预测一直是能源行业的核心挑战之一。随着可再生能源占比提升和用电模式多样化,传统统计方法在预测精度和灵活性上逐渐显露出局限性。今天我们将深入探…...

3大核心技术打造专业简历:Magic Resume零门槛开源工具全解析

3大核心技术打造专业简历:Magic Resume零门槛开源工具全解析 【免费下载链接】magic-resume free online AI resume editor 项目地址: https://gitcode.com/GitHub_Trending/ma/magic-resume 在竞争激烈的求职市场中,一份专业且个性化的简历往往是…...

ChatGPT4.0免费版与付费版的区别:如何避免被假网站坑?

ChatGPT4.0免费版与付费版深度对比:识别陷阱与优化选择 在人工智能技术快速发展的今天,ChatGPT4.0已成为许多用户日常工作和学习的重要工具。然而,市场上关于免费与付费版本的混淆信息层出不穷,甚至出现了大量仿冒网站。本文将为您…...

【OpenClaw从入门到精通】第33篇:端侧AI爆发元年!OpenClaw在智能眼镜/AI手机/汽车上的部署实测与实操指南(2026版)

摘要:2026年成为端侧AI爆发关键节点,OpenClaw已从桌面工具延伸至智能眼镜、AI手机、智能汽车等终端设备。本文基于Rokid、小米、华为等厂商公开技术资料与实测数据,系统解析端侧Agent的核心原理、三层能力架构,聚焦三大核心场景(智能眼镜实时交互、AI手机系统级服务、汽车…...

专为职场小白设计,会议场景如何取消语音转文字权威指南

作为常年关注AI工具在内容创作和职场场景应用的创作者,我接触过不少职场小白尤其是销售客服、HR群体,他们经常会遇到这样的尴尬:在2026年的混合式会议、客户拜访或面试场景中,开启了语音转文字功能后,突然遇到涉密内容…...

Qwen3-ASR-0.6B开源ASR模型实操手册:从镜像拉取到MP3转文字完整步骤

Qwen3-ASR-0.6B开源ASR模型实操手册:从镜像拉取到MP3转文字完整步骤 1. 模型介绍与准备工作 Qwen3-ASR-0.6B是阿里云通义千问团队开发的开源语音识别模型,这个模型最大的特点就是小而精悍。虽然只有0.6B参数,但在语音识别效果上表现相当不错…...

双向跳点搜索路径规划,起点终点同时开始搜索。 双向JPS搜索,A*的改进算法,代码注释详细,附...

双向跳点搜索路径规划,起点终点同时开始搜索。 双向JPS搜索,A*的改进算法,代码注释详细,附赠参考文献。 附赠单向JPS算法。 matlab源码。算法概述 跳点搜索(Jump Point Search,JPS)是一种基于网…...

uSpeedo Skill教程:一句话自动发送短信与邮件

uSpeedo Skill现已正式上线 ClawHub。无论你想要自动化海外触达,还是发送个性化通知,uSpeedo 都能让你的智能体精准完成短信与邮件投递。 更多详情:https://uspeedo.com/zh/ai-communication?SaleCodeKQ2649 配置前须知 在正式开始配置前&…...

告别命令行恐惧:Super Xray图形化界面实战指南

1. 为什么你需要Super Xray图形化工具 第一次接触xray命令行工具时,我盯着满屏的yaml配置参数发呆了半小时。这不是个例——很多安全工程师都有过被命令行支配的恐惧。传统xray需要手动编辑config.yaml文件,光是反连平台的配置就有十几行代码&#xff0c…...

E-LINK墨水瓶驱动显示数字和图片

简介:E-LINK墨水瓶就是电子纸屏幕,就是kindle电子阅读器用的屏幕,显示效果和纸质很相似,用这种屏幕有两个好处,一个是功耗低,屏幕显示一个画面之后,即使断电也会一直显示,另一个好处…...

计算机网络面试必问:从OSI七层到TCP三次握手,一次搞懂核心概念

计算机网络面试核心概念:从协议栈到实战应答 1. 网络协议栈的生存法则:为什么分层设计永不过时? 当面试官抛出"谈谈你对OSI七层模型的理解"这类问题时,大多数候选人会机械地背诵各层名称。但真正的高手会揭示分层架构背…...

Android 10+免Root修改开机动画?MT管理器隐藏技巧大公开

Android 10免Root修改开机动画实战指南:MT管理器高阶玩法解析 每次点亮手机屏幕时,那个千篇一律的开机动画是否让你感到审美疲劳?对于追求个性化的Android用户来说,修改开机动画是彰显品味的绝佳方式。但传统方法需要Root权限&am…...

从手机到智能手表:ROM、RAM和FLASH在消费电子产品中的实际应用对比

从手机到智能手表:ROM、RAM和FLASH在消费电子产品中的实际应用对比 当你在智能手机上流畅切换应用,或在智能手表上查看健康数据时,背后是三种关键存储器——ROM、RAM和FLASH的精密协作。这些看似晦涩的技术术语,实则决定了我们每天…...