Redis与Mysql双写一致性如何保证?

我们在面试的时候redis与mysql双写一致性是一个常考的问题,今天我们就一起探讨一下吧

所谓的一致性就是数据的一致性,在分布式系统中,可以理解为多个节点中数据的值是一致的。

强一致性: 这种一致性级别是最符合用户直觉的,他要求系统写入什么,读出来的也会是什么,用户体验好,但是实现起来往往对系统的性能影响大

弱一致性: 这种一致性级别约束了系统在写入成功后,不承诺立即可以读到写入的值,也不承诺多久之后数据能够达到一致性,但会尽可能地保证到某个级别(比如毫秒级别)后,数据能够达到一致状态

最终一致性: 最终一致性是弱一致性的一个特例,系统会保证在一定时间内,能够达到一个数据一致的状态。之所以将最终一致性单独提出来,是因为他是弱一致性中非常推崇的一种一致性模型,也是业界在大型分布式系统的数据一致性上比较推崇的模型

延时双删

1,先删除缓存

2,再更新数据库

3,休眠一会,再删除缓存

删除缓存重试机制

1,写请求更新数据库

2,缓存因为某些原因,删除失败

3,把删除失败的key放到消息队列

4,消费消息队列的消息,获取要删除的key

5,重试删除缓存操作

读取binlog异步删除缓存

通过读取数据库binlog日志来异步淘汰key

mysql为例,可以使用canal将binlog日志采集发送到MQ队列里面,然后通过ACK机制确认处理这条更新消息,删除缓存,保证数据缓存一致性

通过redission的读写锁解决缓存一致性问题

读写使用同一把锁,(读读不互斥),(读写,写写互斥)

文章总结自:捡田螺的男孩

相关推荐
wolfengi18 小时前
python之使用docxtpl渲染word模板
数据库·python·word
Wmenghu18 小时前
Ubuntu 安装 MySQL 8.0 + Redis 并开启远程访问
redis·mysql·ubuntu
2401_8314194418 小时前
Layui如何实现表格内部的图片点击后进入相册轮播模式
jvm·数据库·python
Jetev18 小时前
SQL使用JOIN连接更新目标表数据_UPDATE语句结合JOIN语法实现
jvm·数据库·python
2401_8323655218 小时前
如何用最快速度完成Navicat的Linux系统完美安装配置_傻瓜式操作步骤
jvm·数据库·python
Java&Develop18 小时前
dbeaver 如何添加 比如 我输入 sf 回车 编辑器会出现 sql select * from 的快捷
数据库·sql·编辑器
PSLoverS18 小时前
Navicat全局查找与替换字符突然失效怎么办_重置与缓存清理
jvm·数据库·python
m0_6028577619 小时前
如何提升SQL存储过程逻辑复用_封装通用存储过程函数
jvm·数据库·python
Thanks_ks20 小时前
分布式系统中的并发控制与分布式锁机制深度剖析
redis·zookeeper·高并发·分布式锁·架构设计·并发控制·分布式系统
forEverPlume21 小时前
mysql如何实现高可用集群架构_基于MHA环境搭建与部署
jvm·数据库·python