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

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

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

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

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

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

相关推荐
c***032310 分钟前
linux centos8 安装redis 卸载redis
linux·运维·redis
摩拜芯城IC27 分钟前
RS -485/RS -422 全双工收发器 ISO3086TDW芯片参数资料 驱动集成 IC
数据库
e***136233 分钟前
MySQL 常用 SQL 语句大全
数据库·sql·mysql
yueyin1234561 小时前
MySQL 批量插入详解:快速提升大数据导入效率的实战方法
大数据·数据库·mysql
kiss strong1 小时前
同一无线网下两台笔记本,一台访问另一台虚拟机中服务(redis为例)
数据库·redis·缓存
星火开发设计1 小时前
模板参数:类型参数与非类型参数的区别
java·开发语言·前端·数据库·c++·算法
Andy Dennis2 小时前
Redis5种基本数据类型和3种特殊数据类型介绍
redis
山岚的运维笔记2 小时前
SQL Server笔记 -- 第53章:INSERT 第54章:主键
数据库·笔记·sql·microsoft·sqlserver
SQL必知必会2 小时前
SQL 聚合函数详解:COUNT、SUM、AVG、MIN、MAX
数据库·sql
w***29852 小时前
MySQL 创建新用户及授予权限的完整流程
数据库·mysql