Redis和Mysql如何保证数据一致性?

一份数据同时保存在数据库和Redis中,当数据发生变化时需要同时去更新Mysql和Redis,由于这个更新有先后顺序并且它不像Mysql里面的多表事物一样可以满足ACID的事物特性,所以就会出现数据一致性的问题。

对于这种情况解决方案主要有以下几种:

1.先更新数据库再更新缓存

2.先删除缓存再更新数据库

如果先更新数据库再更新缓存,如果缓存更新失败就会导致数据库和Redis中的数据不一致,如果先删除缓存再更新数据库,在理想情况下应用下次访问Redis的时候,发现Redis中的数据是空的,就从数据库中加载保存到Redis中,那么数据看起来就是一致的,但是在极端情况下由于删除Redis和更新数据库这两个操作并不是原子的,所以这个过程中如果有其他线程来访问还是会存在数据不一致的问题,所以如果需要在极端情况下仍然保证Redis和Mysql中的数据一致性就只能采用最终一致性方案。比如基于RocketMQ的可高性消息通信来实现最终一致性,还可以直接通过canal组件监控Mysql中binlog的日志把更新后的数据同步到Redis里面,因为这里面是基于最终一致性来实现的,如果业务场景不能接受数据的短期不一致性,那么我们可以通过读写锁的方式来保证强一致性,在数据更新的时候其他任何请求都无法访问缓存中的数据直到数据更新完毕从而去保证数据的强一致性,但是这种方式由于增加了锁的操作所以在性能上有一定的影响,所以我们在方案的时候一定要做好相关的一个平衡。

相关推荐
linux修理工44 分钟前
kafka积压
数据库·分布式·kafka
i220818 Faiz Ul1 小时前
药店管理|基于springboot + vue药店管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·美食分享系统
不吃土豆的马铃薯1 小时前
C++ 正则表达式入门详解
linux·服务器·网络·数据库·c++·正则表达式
sulikey1 小时前
数据库系统概论 - 定义与查询 期末速成课笔记
数据库·笔记·期末考试·数据查询·期末速成·数据库系统概论·数据定义
nan madol1 小时前
PolarDB 分布式版(PolarDB-X)
数据库
西凉的悲伤1 小时前
redis-windows 安装 redis 到 windows 电脑
java·windows·redis·redis-windows
johnny2331 小时前
数据库客户端:DBGate、DBX、dblab、SQLQueryStress、openhare、DBcooper、RedisME
数据库
IT策士1 小时前
Redis 从入门到精通:缓存经典难题 —— 穿透、击穿、雪崩
数据库·redis·缓存
huisheng_qaq1 小时前
【项目篇-01】Vmware虚拟机和环境安装配置
redis·mysql·canal·rocketmq·es·vaware虚拟机
湘美书院--湘美谈教育1 小时前
湘美谈教育湘美书院考古教育系列:湖南史前文化序列整理
大数据·数据库·人工智能·深度学习·神经网络·机器学习