Redis 延迟双删的实现示例

 更新时间:2026年05月08日 08:25:58   作者:哈里谢顿  
延迟双删是在Cache-Aside基础上,为了解决并发读写导致缓存回填旧值问题而设计的方案,本文就来详细的介绍一下Redis 延迟双删的实现示例,感兴趣的可以了解一下

延迟双删(Delayed Double Deletion) 是在 Cache-Aside 基础上,为了解决"并发读写导致缓存回填旧值"问题而设计的方案。

一、问题背景:为什么需要双删?

先看单删的问题场景(先删缓存,再更新DB):

时间点  线程A(写)              线程B(读)
  t1    删除缓存
  t2                            查询缓存(未命中)
  t3                            查询数据库 → 得到旧值
  t4    更新数据库为新值
  t5                            将旧值写入缓存  ← 缓存变脏!

即使你先更新DB再删缓存,也有类似风险:

时间点  线程A(写)              线程B(读)
  t1    更新数据库
  t2                            查询数据库 → 得到旧值(因主从延迟等)
  t3    删除缓存
  t4                            将旧值写入缓存  ← 缓存变脏!

延迟双删的核心思想:等一等,让并发的读请求都结束了,再把缓存清掉。

二、延迟双删的具体步骤

1. 先删除缓存
2. 更新数据库
3. 休眠/等待一段时间(比如 200ms~1s)
4. 再次删除缓存

用代码表示:

import time
def update_with_delayed_double_deletion(key, new_value):
    # 第一次删缓存
    redis.delete(key)
    # 更新数据库
    db.update(key, new_value)
    # 延迟一段时间(关键!)
    time.sleep(0.5)  # 500ms,根据业务调整
    # 第二次删缓存(把可能回填的旧值清掉)
    redis.delete(key)

三、延迟时间怎么定?

这是最关键的参数,定太短没效果,定太长影响性能。

建议公式:

延迟时间 ≈ 主从同步延迟 + 业务读操作耗时 + 冗余缓冲

  • 主从同步延迟:如果有主从架构,通常 100ms~500ms
  • 业务读操作耗时:查询DB + 序列化 + 网络往返
  • 冗余缓冲:再加 100~200ms 保险

实际建议:

  • 无主从:100~300ms
  • 有主从:300~800ms
  • 高并发场景:可以动态调整,或根据监控数据优化

四、第二次删除失败怎么办?

如果第二次删缓存时 Redis 挂了或网络抖动,缓存还是会脏。

解决方案:引入异步重试

import threading
def update_with_retry(key, new_value):
    # 第一次删 + 更新DB
    redis.delete(key)
    db.update(key, new_value)
    # 延迟后异步执行第二次删除
    def delayed_delete():
        time.sleep(0.5)
        try:
            redis.delete(key)
        except Exception:
            # 失败则放入重试队列(MQ 或本地延迟队列)
            retry_queue.put(key)
    threading.Thread(target=delayed_delete).start()

更生产化的做法是用 消息队列延迟任务框架(如 Celery、XXL-Job)来做第二次删除,确保可靠执行。

五、完整流程图

写请求到来
    │
    ▼
┌─────────────┐
│  删除缓存    │◄── 第一次删除,清掉旧值
└─────────────┘
    │
    ▼
┌─────────────┐
│  更新数据库  │
└─────────────┘
    │
    ▼
┌─────────────┐
│  延迟等待    │◄── 等并发读请求结束,旧值回填完成
└─────────────┘
    │
    ▼
┌─────────────┐
│  再次删除缓存 │◄── 第二次删除,清掉可能回填的旧值
│  (带重试)  │
└─────────────┘
    │
    ▼
   结束

六、优缺点总结

优点缺点
实现简单,不引入额外组件延迟等待会阻塞写请求(或用异步)
能有效降低缓存不一致概率延迟时间不好精确估算
兼容现有 Cache-Aside 架构极端高并发下仍可能有小概率不一致

七、适用场景

  • 读多写少:写操作不频繁,延迟等待的开销可接受
  • 允许秒级最终一致:不要求实时强一致
  • 无主从或主从延迟可控:延迟时间能估算得准

八、一句话总结

延迟双删 = "先删缓存 → 更新DB → 等一会儿 → 再删一次",用"等一等"来覆盖并发读回填旧值的时间窗口。

 到此这篇关于Redis 延迟双删的实现示例的文章就介绍到这了,更多相关Redis 延迟双删内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Redis实现每日签到功能(大数据量)

    Redis实现每日签到功能(大数据量)

    在面对百万级用户签到情况下,传统数据库存储和判断会遇到瓶颈,使用Redis的二进制数据类型可实现高效的签到功能,示例代码展示了如何调用这些功能,包括当天签到、补签以及查询签到记录,PHP结合Redis二进制数据类型可有效处理大数据量下的签到问题
    2024-10-10
  • redis的Cacheable注解使用及说明

    redis的Cacheable注解使用及说明

    文章介绍了如何在Java应用中使用Spring的@Cacheable注解进行缓存配置,包括注解的使用、key的生成方式、触发条件(condition)和排除条件(unless)的设置,并强调了缓存的持久性和清除机制
    2025-11-11
  • Redis Server启动过程的详细步骤

    Redis Server启动过程的详细步骤

    本文主要介绍了Redis Server启动过程的详细步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Redis实现集群搭建+集群读写的示例

    Redis实现集群搭建+集群读写的示例

    本文介绍了Redis集群的搭建和读写操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-02-02
  • 利用yum安装Redis的方法详解

    利用yum安装Redis的方法详解

    Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。这篇文章主要介绍的是利用yum安装Redis的方法,有需要的朋友们可以参考借鉴,下面来一起看看吧
    2016-11-11
  • 使用Redis实现分布式锁的方法

    使用Redis实现分布式锁的方法

    为了保证我们线上服务的并发性和安全性,目前我们的服务一般抛弃了单体应用,采用的都是扩展性很强的分布式架构,这篇文章主要介绍了使用Redis实现分布式锁的方法,需要的朋友可以参考下
    2022-06-06
  • redis批量删除namespace下的数据的实现步骤

    redis批量删除namespace下的数据的实现步骤

    在开发中为了更好的管理数据,对redis进行了分组存储操作,在存值时加了命名空间来实现,本文就来介绍一下redis批量删除namespace下的数据的实现步骤,感兴趣的可以了解一下
    2025-12-12
  • Redis分布式锁升级版RedLock及SpringBoot实现方法

    Redis分布式锁升级版RedLock及SpringBoot实现方法

    这篇文章主要介绍了Redis分布式锁升级版RedLock及SpringBoot实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Redis远程连接Redis客户端的实现步骤

    Redis远程连接Redis客户端的实现步骤

    本文主要介绍了Redis远程连接Redis客户端的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • redis服务器允许远程主机访问的方法

    redis服务器允许远程主机访问的方法

    今天小编就为大家分享一篇redis服务器允许远程主机访问的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05

最新评论