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

如何保证 Redis 缓存和数据库的一致性?

如何保证 Redis 缓存和数据库的一致性?

1. 问题出现场景

  1. 先修改数据库,再删除缓存

    删除数据库数据成功了,但是删除缓存却失败了,缓存中仍保留的是旧数据

  2. 先删除缓存,再删除数据库

    如果 Redis 缓存删除成功后,假如数据库数据还没来得及更新,用户又请求数据,这时就会从数据库中读取旧的值,存入到 Redis 中,用户查到的数据依旧是旧的数据。

2. 解决方案

2.1 双写事务

原理:利用 Redis 的事务特性,或是数据库的事务特性,把 Redis 操作和数据库操作放到同一个事务中去执行,同时提交或回滚,最大程度上保证 Redis 缓存和数据库的一致。

  1. 优点:实现简单、不复杂,能够保证一定的一致性

  2. 缺点:

    Redis 和数据库本质不是同一种数据库,所以无法通过事务来保证它们之间完全的一致性

适合小型系统的简单读写,不适合高并发系统。

2.2 延迟双删

原理:当完成数据库的更新时,立即删除 Redis 缓存,为了确保数据更新的稳妥,延迟一定时间后(例如 1s、2s),再次对缓存进行删除。

目的:避免并发操作导致缓存脏数据的问题出现

  1. 优点:实现简单,能够解决大部分场景下短时间数据不一致的情况
  2. 缺点:延迟时间非常难以精确控制,如果操作量比较大,可能还会出现覆盖的风险

2.3 订阅更新机制

原理:当数据库更新,会向消息队列发送一条消息,Redis 通过订阅这个消息队列,来更新缓存数据,这样会让更新和缓存的清除变得非常及时。

  1. 优点:同步效果非常好
  2. 缺点:系统的复杂度会增加,消息队列本身需要一些可靠性,也是需要一些维护成本

2.4 读写分离架构

高并发场景应用非常广泛

原理:把写操作全部直接操作数据库,然后通过一个异步线程、后台服务、定时任务,去更新 Redis 缓存,从而实现数据的一致性。

  1. 优点:缓存压力降低很多,特别适合大数据流量的系统
  2. 缺点:项目开发比较复杂,因为要做好这种异步的逻辑的处理

2.5 Canal 订阅 Binlog 同步 Redis

原理:修改数据库的同时,数据库的操作会同时写入到 Binlog 中,这时可以通过 Canal 中间键,来订阅 Binlog 的一些变化,如果监听到数据库变化之后,把更新的数据同步通知给 Redis,来更新 Redis 的缓存

3. 总结

3.1 哪儿种方案更好?

具体选择哪儿种解决方案,要根据具体业务场景、项目的需求,以及整体的架构等多种因素去综合考虑,比如是否是高并发、是否要考虑低延迟等等因素。

脱离业务谈技术,就是耍流氓。

3.2 归纳

虽然这几种解决方案,可以在一定程度上解决 Redis 和数据库不一致的情况,但是在实际情况种,还要结合业务,来判断项目中是否真的需要,或是项目中可以使用 Redis。如果业务需要强一致性,例如银行、股票等业务,其实不使用 Redis 其实也是一种很好的方案。

相关文章:

  • 在编译Linux的内核镜像和模块时,必须先编译内核镜像,再编译模块,顺序不可随意调整的原因
  • 备战蓝桥杯Day11 DFS
  • React 常见面试题及答案
  • Mysql系统表
  • 【考试大纲】中级信息安全工程师考试大纲
  • HTMLS基本结构及标签
  • 神经网络之CNN图像识别(torch api 调用)
  • 建易WordPress
  • 算法-二叉树篇23-二叉搜索树中的插入操作
  • 夜天之书 #106 Apache 软件基金会如何投票选举?
  • Java 大视界 -- Java 大数据在智能安防入侵检测与行为分析中的应用(108)
  • AF3 DataPipeline类process_core 方法解读
  • sql server 版本更新日期
  • 经典算法 金币阵列问题
  • 【SpringCloud】黑马微服务学习笔记
  • 考虑复杂遭遇场景下的COLREG,基于模型预测人工势场的船舶运动规划方法附Matlab代码
  • 【Nginx】在Windows服务器上用Nginx部署Vue前端全流程(附避坑指南)
  • 全监督、半监督、弱监督、无监督
  • 【Python篇】PyQt5 超详细教程——由入门到精通(序篇)
  • PDF文件转换为PNG图像
  • 乐清网站建设/安徽网站seo
  • 网页设计代码quot/seo专业技术培训
  • 免费全能网站空间/今天的特大新闻有哪些
  • 企业推广策划公司/seo网站推广助理招聘
  • 泉州地区网站建设公司/怎么给客户推广自己的产品
  • 北京网站设计公司jq成都柚米科技15/友情链接交换网址大全