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

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

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

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

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

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

延时双删

1,先删除缓存

2,再更新数据库

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

删除缓存重试机制

1,写请求更新数据库

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

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

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

5,重试删除缓存操作

读取binlog异步删除缓存

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

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

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

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

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

相关推荐
5***E6859 分钟前
【SQL】写SQL查询时,常用到的日期函数
数据库·sql
遇见火星27 分钟前
CentOS7 通过源码安装 Redis
数据库·redis·缓存
Mr.朱鹏34 分钟前
RocketMQ安装与部署指南
java·数据库·spring·oracle·maven·rocketmq·seata
Coder-coco37 分钟前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
K哥112539 分钟前
【9天Redis系列】基础+全局命令
数据库·redis·缓存
s***46981 小时前
【玩转全栈】----Django模板语法、请求与响应
数据库·python·django
f***R81 小时前
redis分页查询
数据库·redis·缓存
g***72701 小时前
【mysql】导出导入mysql表结构或者数据
数据库·mysql
煎蛋学姐1 小时前
SSM汽车租赁管理系统mfobv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·汽车·ssm 框架·汽车租赁管理系统
w***37511 小时前
Spring 核心技术解析【纯干货版】- Ⅶ:Spring 切面编程模块 Spring-Instrument 模块精讲
前端·数据库·spring