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

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

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

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

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

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

延时双删

1,先删除缓存

2,再更新数据库

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

删除缓存重试机制

1,写请求更新数据库

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

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

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

5,重试删除缓存操作

读取binlog异步删除缓存

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

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

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

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

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

相关推荐
小叶子来了啊4 分钟前
软考(信息系统运行管理员)
数据库
chunfeng—7 分钟前
Redis 主从同步与对象模型(四)
数据库·redis·缓存·集群·哨兵
Leo.yuan1 小时前
热力图是什么?三分钟学会热力图数据分析怎么做!
大数据·数据库·数据挖掘·数据分析·html
张哈大1 小时前
【 Redis | 实战篇 缓存 】
数据库·redis·笔记·spring·缓存
玩转数据库管理工具FOR DBLENS1 小时前
项目高压生存指南:科学重构身体与认知系统的抗压算法
大数据·数据库·职场和发展·项目管理
xiaogai_gai1 小时前
高效管理钉钉收款单数据集成到MySQL的技术方案
android·mysql·钉钉
正在走向自律2 小时前
【金仓数据库征文】学校AI数字人:从Sql Server到KingbaseES的数据库转型之路
数据库·人工智能·kingbasees·金仓数据库 2025 征文·数据库平替用金仓
_extraordinary_2 小时前
MySQL 索引(一)
android·数据库·mysql
gjc5922 小时前
MySQL OCP试题解析(2)
android·数据库·mysql·开闭原则
Code哈哈笑2 小时前
【图书管理系统】深度讲解:图书列表展示的后端实现、高内聚低耦合的应用、前端代码讲解
java·前端·数据库·spring boot·后端