MySQL和Redis的数据一致性

MySQL和Redis的数据一致性

多线程环境下的涉及读写的缓存才会存在MySQL和Redis的数据不一致问题

先删除缓存再更新数据库再延时删除缓存
  1. 线程一删除缓存
  2. 线程一更新数据
  3. 线程二开始查数据
  4. 如果第二步线程一更新数据延时,那么线程二会重新从数据库加载数据,并将失效的数据设置到缓存
  5. 线程一更新完成数据库值之后,第二次延时删除缓存;延时删除是因为可能存在线程二查库返回失效数据还未将失效数据设置到缓存中时,线程一更新了数据库并立即删除了缓存,此时线程二会再一次将失效数据设置到缓存中,所以需要延时删除缓存,具体延时需要根据系统并发业务量判断
先更新数据库再删除缓存
  1. 线程一更新数据库
  2. 线程二开始读取缓存,在线程一还未删除缓存的时候,线程二一直读取失效数据
  3. 线程一删除缓存


双删机制还是会有概率导致MySQL和Redis的数据一致性,特别是当你第二次延时删除时间设置的不合适的时候,所以建议使用先更新数据库再删除缓存的方式,这样可以保证数据库的最终一致性。无论是哪一种删除机制都会存在缓存删除失败的情况,所以要引入缓存删除重试机制。下面是两种缓存删除重试机制

引入MQ缓存删除重试
  1. 更新数据库完成之后删除缓存
  2. 如果缓存删除失败,异步向MQ发送删除失败的缓存key
  3. 应用程序监听MQ,重试缓存删除,如果一直失败超过一定次数需要通知运维人员人工介入
引入MySQL的binlog订阅机制监听数据库数据变动处理缓存更新

和上面不一样的地方在于,我们使用的独立的Canal客户端订阅MySQL的binlog日志来执行缓存删除,而不是由主线程在更新数据库之后删除缓存,这在一定程度上实现了业务数据更新和缓存删除的解耦

相关推荐
在未来等你19 分钟前
SQL进阶之旅 Day 21:临时表与内存表应用
sql·mysql·postgresql·database·temporary-table·memory-table·sql-optimization
敖云岚1 小时前
【Redis】分布式锁的介绍与演进之路
数据库·redis·分布式
LUCIAZZZ1 小时前
HikariCP数据库连接池原理解析
java·jvm·数据库·spring·springboot·线程池·连接池
我在北京coding2 小时前
300道GaussDB(WMS)题目及答案。
数据库·gaussdb
小Tomkk2 小时前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台3 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
让我上个超影吧3 小时前
黑马点评【基于redis实现共享session登录】
java·redis
沉到海底去吧Go3 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局4 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务4 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库