返回顶部
首页 > 资讯 > 数据库 >redis延迟双删策略示例讲解
  • 404
分享到

redis延迟双删策略示例讲解

redis延迟双删redis延迟双删策略redis延时双删实现 2023-04-14 11:04:59 404人浏览 安东尼
摘要

目录1、什么是延迟双删?2、为什么要进行延迟双删?3、对于方案处理都有弊端,那么我们需要使用延迟双删策略4、需要注意的点5、延迟的时间如何确定?小结在当前环境下,通常我们会首选Redis缓存来减轻我们数据库访问压力。但是

在当前环境下,通常我们会首选Redis缓存来减轻我们数据库访问压力。但是也会遇到以下这种情况:大量用户来访问我们系统,首先会去查询缓存, 如果缓存中没有数据,则去查询数据库,然后更新数据到缓存中,并且如果数据库中的数据发生了改变则需要同步到redis中,同步过程中需要保证 Mysql与redis数据一致性问题,在这个同步过程中出现短暂的数据延迟也是正常现象,但是最终需要保证mysql与缓存中的一致性。

//我们通常使用redis的逻辑
    //通常我们是先查询reids
    String value = RedisUtils.get(key);
    if (!StringUtils.isEmpty(value)){
        return value;
    }
//从数据库中获取数据
    value = getValueForDb(key);
    if (!StringUtils.isEmpty(value)){
           RedisUtils.set(key,value);
        return value;
     }

1、什么是延迟双删?

延迟双删策略是分布式系统中数据库存储和缓存数据保持一致性的常用策略,但它不是强一致。其实不管哪种方案,都避免不了Redis存在脏数据的问题,只能减轻这个问题,要想彻底解决,得要用到同步和对应的业务逻辑层面解决。

2、为什么要进行延迟双删?

一般我们在更新数据库数据时,需要同步redis中缓存的数据 所以我们一般会给出两种方案:

  • 第一种方案:先执行update操作,再执行缓存清除。
  • 第二种方案:先执行缓存清除,再执行update操作。

但是这两种方案在并发请求中容易出现以下问题

redis延迟双删策略示例讲解

第一种方案弊端:当请求1去执行数据库更新操作之后,还没执行缓存清除时,请求2就进来了查询了缓存,此时缓存中数据还是旧数据,还没来得机删除导致数据出现问题,但是当t1执行缓存删除操作之后,后面的请求查询不到缓存,再到数据中查询,然后更新到缓存中,这种影响是比较小的

  1. t1线程 先更新db;
  2. t2线程查询命中缓存 返回旧的数据;
  3. 假设t1线程更新完db,预计5毫秒删除完缓存key 在5毫秒内 其他线程查询缓存结果还是为旧的数据,但是 5毫秒后查询缓存结果是为空,在从新将db最新的结果同步到Redis中。
  4. 一个项目中出现延迟是非常正常的,所以该情况发生的延迟对业务的影响其实很小。但是如果发生了,删除缓存失败呢?

1.不断重试----如果是在Http协议接口中 会导致接口响应变慢 调用该接口 会发生响应超时 2.或者通过MQ异步的形式同步

redis延迟双删策略示例讲解

第二种方案弊端:当请求1执行清除缓存后,还未执行数据更新操作的时,请求2进来查询到数据库的旧数据,并写入了redis,这就导致了数据库与redis数据不一致问题。

  • t1线程先删除缓存;
  • t2线程读取缓存为null,同步db数据到缓存中;
  • t1线程更新db中的数据;
  • t3线程查询缓存中数据是旧数据;

3、对于方案处理都有弊端,那么我们需要使用延迟双删策略

先进行缓存清除,再执行update,最后(延迟N秒)再执行缓存清除。进行两次删除,且中间需要延迟一段时间

    RedisUtils.del(key);// 先删除缓存    updateDB(user);// 更新db中的数据    Thread.sleep(N);// 延迟一段时间,在删除该缓存key    RedisUtils.del(key);// 先删除缓存

4、需要注意的点

上述中(延迟N秒)的时间要大于一次写操作的时间。原因:如果延迟时间小于写入redis的时间,会导致请求1清除了缓存,但是请求2缓存还未写入的尴尬。。。

5、延迟的时间如何确定?

在业务程序运行时,统计业务逻辑执行读数据和写缓存的操作时间,以此为基础来进行估算。因为这个方案会在第一次删除缓存值后,延迟一段时间再次进行删除,所以称为“延迟双删”。

小结

延迟双删策略只是一种同步数据库与缓存的手段,在系统并发量不高的情况下可以使用这种方式解决,如果是并发量高的情况下我们也可以另寻其他解决方案 如:canal

到此这篇关于redis延迟双删策略的文章就介绍到这了,更多相关redis延迟双删策略内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: redis延迟双删策略示例讲解

本文链接: https://lsjlt.com/news/201541.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • redis延迟双删策略示例讲解
    目录1、什么是延迟双删?2、为什么要进行延迟双删?3、对于方案处理都有弊端,那么我们需要使用延迟双删策略4、需要注意的点5、延迟的时间如何确定?小结在当前环境下,通常我们会首选Redis缓存来减轻我们数据库访问压力。但是...
    99+
    2023-04-14
    redis 延迟双删 redis延迟双删策略 redis延时双删实现
  • redis延迟双删策略
    在当前环境下,通常我们会首选redis缓存来减轻我们数据库访问压力。但是也会遇到以下这种情况:大量用户来访问我们系统,首先会去查询缓存, 如果缓存中没有数据,则去查询数据库,然后更新数据到缓存中,并且如果数据库中的数据发生了改变则需要同步到...
    99+
    2023-09-03
    redis java Powered by 金山文档
  • redis延迟双删策略怎么使用
    这篇文章主要讲解了“redis延迟双删策略怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“redis延迟双删策略怎么使用”吧!在当前环境下,通常我们会首选redis缓存来减轻我们数据库...
    99+
    2023-07-06
  • 关于redis的延迟双删策略总结
    目录Redis延迟双删策略1、什么是延迟双删?2、为什么要进行延迟双删?3、如何实现延迟双删?4、需要注意的点5、小结redis为什么要延时双删redis延迟双删策略 1、什么是延迟双删? 延迟双删策略是分布式系统中数据...
    99+
    2024-04-02
  • Redis中键的过期删除策略深入讲解
    如果一个键过期了,那么它什么时候会被删除呢? 这个问题有三种可能的答案,它们分别代表了三种不同的删除策略: 定时删除:在设置键的过期时间的同时,创建一个定时器( timer ). 让定时器...
    99+
    2024-04-02
  • MySQL中延迟问题和数据刷盘策略流程的示例分析
    这篇文章给大家分享的是有关MySQL中延迟问题和数据刷盘策略流程的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、MySQL复制流程官方文档流程如下:MySQL延迟问题...
    99+
    2024-04-02
  • Redis缓存策略超详细讲解
    目录Redis缓存中间件缓存是什么缓存的优点缓存的缺点Redis缓存已查询数据redis缓存中间件实践缓存更新缓存更新的三个策略主动更新策略的三种方案主动更新的代码实现Redis缓存...
    99+
    2024-04-02
  • 解决阿里云服务器画面延迟问的策略
    阿里云服务器是许多企业和个人使用的重要工具,但是画面延迟问题一直是困扰用户的一大难题。本篇文章将为您详细介绍解决阿里云服务器画面延迟问题的策略。 一、了解画面延迟的原因画面延迟是由于网络传输数据的速度慢导致的。主要有以下几个原因:网络带宽不...
    99+
    2023-11-23
    阿里 画面 策略
  • Redis中过期策略的示例分析
    小编给大家分享一下Redis中过期策略的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!概述设置过期时间expire key time(以秒为单位) 这是最...
    99+
    2023-06-15
  • Java之策略模式比较器案例讲解
    Comparable 比较器,内置定义的比较方法,实现比较 较简单 Comparator 策略模式,需要定义不同的策略和比较的对象,实现比较 较复杂 打个比方,狗有foot一种属性我...
    99+
    2024-04-02
  • Java DelayQueue实现任务延时示例讲解
    在项目中有使用到延时队列的场景,做个简单的记录说明;首先DelayQueue实现了BlockingQueue,加入其中的元素必须实现Delayed接口; 当生产者元素调用put往其中...
    99+
    2024-04-02
  • SpringBoot整合RabbitMQ实现延迟队列的示例详解
    目录如何保证消息不丢失什么是消息投递可靠性ttl死信队列什么是死信队列消息有哪几种情况成为死信延迟队列springboot整合rabbitmq实现订单超时自动关闭如何保证消息不丢失 ...
    99+
    2023-05-16
    SpringBoot RabbitMQ实现延迟队列 SpringBoot RabbitMQ延迟队列 SpringBoot RabbitMQ队列 SpringBoot RabbitMQ
  • Redis过期键与内存淘汰策略深入分析讲解
    目录一、Redis数据库的组织方式1.1 redisServer结构定义1.2 redisDb 结构定义1.3 redisdb初始化二、过期键2.1 设置键的过期时间2.2 过期键的判定2.3 过期键的删除策略2.3.1...
    99+
    2022-11-28
    Redis过期键 Redis内存淘汰策略
  • Redis中过期操作和过期策略的示例分析
    这篇文章主要介绍Redis中过期操作和过期策略的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!过期操作过期设置Redis 中设置过期时间主要通过以下四种方式:expire k...
    99+
    2024-04-02
  • redis 过期策略及内存回收机制的示例分析
    这篇文章主要介绍了redis 过期策略及内存回收机制的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。redis作为缓存的场景下,内存淘汰策略决定的redis的内存使用...
    99+
    2023-06-25
  • Java设计模式之策略模式示例详解
    目录定义结构UML类图UML序列图深入理解策略模式策略和上下文的关系策略模式在JDK中的应用该策略接口有四个实现类策略模式的优点策略模式的缺点策略模式的本质在讲策略模式之前,我们先看...
    99+
    2024-04-02
  • 举例讲解iOS中延迟加载和上拉刷新/下拉加载的实现
    lazy懒加载(延迟加载)UITableView 举个例子,当我们在用网易新闻App时,看着那么多的新闻,并不是所有的都是我们感兴趣的,有的时候我们只是很快的滑过,想要快速的略过不喜...
    99+
    2022-06-02
    iOS 加载
  • Spring Cloud Ribbon 负载均衡使用策略示例详解
    目录一、前言二、什么是 Ribbon2.1 ribbon简介2.1.1  ribbon在负载均衡中的角色2.2 客户端负载均衡2.3 服务端负...
    99+
    2023-03-13
    Spring Cloud Ribbon 负载均衡使用策略 Spring Cloud Ribbon 负载均衡策略
  • Input系统分发策略及其应用示例详解
    目录引言分发策略原理分发策略的应用 - 组合键结束引言 Input系统: 按键事件分发 从整体上描绘了通用的事件分发过程,其中有两个比较的环节,一个是截断策略,一个是分发策略。In...
    99+
    2023-02-03
    Input系统分发策略 Input分发策略
  • java设计模式策略模式图文示例详解
    目录策略模式意图问题解决方案真实世界类比策略模式结构伪代码策略模式适合应用场景实现方式策略模式优缺点策略模式优缺点与其他模式的关系策略模式 亦称:Strategy 意图 策略模式是一...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作