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

redis延时双删,为什么第一次删除

Redis延时双删策略中第一次删除的作用

在缓存与数据库一致性方案中,"延时双删"(Delayed Double-Delete)是一种经典策略,其核心流程如下:

  1. 第一次删除:更新数据库前,先删除缓存

  2. 更新数据库:执行数据库写操作

  3. 第二次删除:延迟一段时间后,再次删除缓存


第一次删除的核心作用
1. 防止旧缓存污染
  • 场景:在并发写请求时,如果没有第一次删除:

    • 线程A更新数据库(新值)

    • 线程B在A更新数据库后但未删除缓存前,读取了旧缓存

    • 结果:缓存中残留旧数据,导致不一致

  • 第一次删除确保更新数据库前,缓存已被清除,强制后续读请求回源到数据库获取最新值。

2. 降低“写后读”不一致窗口期
  • 即使有并发读请求在第一次删除后、数据库更新前发生:

    • 由于缓存已被删除,读请求会从数据库加载即将更新的新值(而非旧值)。

    • 比不删除缓存直接更新数据库的窗口期更短。

3. 配合第二次删除形成“双保险”
  • 第一次删除:主动清除可能的脏数据

  • 第二次删除(延迟后):清理并发读请求可能引入的旧缓存

  • 两者结合可将不一致时间窗口压缩到毫秒级。


为什么需要第二次删除?

第一次删除无法完全避免以下场景:

  1. 并发读请求在第一次删除后、数据库更新前发生

    • 线程A删除缓存(第一次删除)

    • 线程B读缓存未命中,从数据库读取旧值并回填缓存

    • 线程A更新数据库为新值

    • 结果:缓存中是旧数据

  2. 数据库主从延迟

    • 从库未同步最新数据时,读请求可能读取到旧值并回填缓存。

第二次删除通过延迟清理(通常500ms-1s)确保:

  • 主从数据库已完成同步

  • 并发读请求的旧缓存已回填并被清理


完整流程示例

图表

代码

下载

DBCacheClientDBCacheClient延迟时间需覆盖:- 主从同步耗时- 并发读请求处理时间1. 第一次删除缓存(DEL key)2. 更新数据库(UPDATE)3. 延迟后第二次删除(DEL key)


适用场景
  • 写多读少:频繁更新时减少缓存不一致风险

  • 对一致性要求较高:如金融、订单状态等业务

  • 无法使用订阅数据库日志(如Canal)的场景


注意事项
  1. 延迟时间设置

    • 通常500ms-1s,需根据主从同步时间和业务RT调整

    • 过长:影响实时性;过短:可能未覆盖脏数据回填

  2. 删除失败处理

    • 建议增加重试机制或异步消息队列保障删除成功

  3. 替代方案

    • 更强一致性方案:Redisson分布式锁 + 串行化读写

    • 最终一致性方案:订阅数据库Binlog(如Canal)自动更新缓存

第一次删除是延时双删的前置防御,第二次删除是后置补偿,两者结合才能最大化降低不一致风险。

http://www.xdnf.cn/news/14865.html

相关文章:

  • 什么是 Solidity 以太坊上主流合约语言?
  • 【大语言模型入门】—— 浅析LLM基座—Transformer原理
  • Hive SQL 快速入门指南
  • Linux基本命令篇 —— less命令
  • 华为云Flexus+DeepSeek征文|利用华为云一键部署的Dify平台构建高效智能电商客服系统实战
  • 【论文阅读笔记】知网SCI——基于主成分分析的空间外差干涉数据校正研究
  • java进阶
  • 基于Uniapp+SpringBoot+Vue 的在线商城小程序
  • matplotlib 绘制水平柱状图
  • Java面试题030:一文深入了解MySQL(2)
  • Geollama 辅助笔记:raw_to_prompt_strings_geo.py
  • 印度和澳洲的地理因素
  • BUUCTF [ACTF新生赛2020]music 1
  • TCP 和 UDP 是什么?
  • nginx基本使用 linux(mac下的)
  • MSPM0G3507之GPIO配置报错 #Sysconfig报错
  • 数据结构与算法 --- 双向链表
  • 从 AJAX 到 axios:前端与服务器通信实战指南
  • VR训练美国服务器:高性能解决方案与优化指南
  • 可编程逻辑器件的发展与比较
  • 逆向入门(22)程序逆向篇-TraceMe
  • FPGA设计的上板调试
  • Cisco FMC events无法加载并且cpu high故障- Cisco bug
  • Grab×亚矩阵云手机:以“云端超级节点”重塑东南亚出行与数字生活生态
  • AngularJS Git 提交消息规范
  • VS Code 配置本地 Dev Container
  • (LeetCode 每日一题) 2099. 找到和最大的长度为 K 的子序列 (排序)
  • 翻译服务器
  • SpringMVC系列(七)(Restful架构风格(下))(完结篇)
  • 第一章 从零开始学习大型语言模型-搭建环境