码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MySQL和Redis的双写一致性


    什么是双写一致性问题?

    先看看我们redis读取过程:

    (1)先读cache,如果数据命中则返回
    (2)如果数据未命中则读db
    (3)将db中读取出来的数据入缓存

    策略1:先更新缓存,再更新数据库
    如果跟新缓存成功更新数据库失败,那么就会造成缓存脏数据

    策略2:先更新数据库,再更新缓存
    高并发会出现这种情况:

    在这里插入图片描述

    线程A跟新数据库,由于网络或者其他原因,这个时候没有来得及跟新缓存的时候,线程跟新了数据库,并且跟新了缓存,但是A 又跟新了缓存。导致我们的线程B跟新丢失

    策略3:先删除缓存,再更新数据库

    先删除缓存再跟新数据库,这种就是以及缓解了策略2的缓存跟新丢失情况,但是依然可能不一致

    A要删除缓存,B去读操作,发现再redis中没有命中,所以B线程要去数据库中读取,并将这个数据写到redis中,然后线程A完成对数据库的跟新,就出现了数据库和redis缓存不一致的情况

    在这里插入图片描述

    如何解决:
    只需要在线程A完成数据库跟新后,再删除 一次缓存,这就叫做延迟双删,这里的延迟时间一定要大于我们的业务的读取的时间

    策略4:先更新数据库,再删除缓存

    当我们A查询数据,正准备写入缓存的时候,线程B更新了数据库,然后执行了删除缓存的操作,然后A才把之前的旧值写入到redis。出现概率很低,因为写操作时间大概率大于读操作时间

    解决方法:
    延迟双删,但是删除失败怎么办?
    那就不断地循环删除了,我们可以将要删除的key放入队列,然后重复尝试删除,直到成功

  • 相关阅读:
    MyBatisPlus详解(二)条件构造器Wrapper、自定义SQL、Service接口
    什么是jsp?与servlet区别?request responds cookies session 整理与使用?controller与servlet的区别?
    SIP中继与VoIP:有何不同?
    甘露糖-聚乙二醇-CY5 Cy5-PEG-mannose
    nested exception is javax.mail.MessagingException: Exception reading response
    9个值得收藏的WebGL性能优化技巧
    接口测试全流程扫盲
    C++算法:最短回文串
    AndroidStudio报错:Plugin with id ‘kotlin-android‘ not found.
    上海建筑模板厂家:承载城市梦想的力量
  • 原文地址:https://blog.csdn.net/qq_52563729/article/details/126040707
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号