数据库缓存一致性问题

缓存一致性

1.更新数据库后更新缓存

在这里插入图片描述

2.更新数据库前更新缓存

在这里插入图片描述

3.更新数据库前删除缓存

正常策略
在这里插入图片描述
延迟策略
在这里插入图片描述

4.更新数据库后删除缓存

场景1
在这里插入图片描述
场景2
在这里插入图片描述

5.解决方法

1.MQ中间件
把更新缓存的操作以 MQ 消息的方式发送出去,由不同的系统或者专门的一个系统进行订阅,而做聚合的操作。不同业务系统订阅 MQ 消息单独维护各自的缓存 Key,专门更新缓存的服务订阅 MQ 消息维护所有相关 Key 的缓存操作。

2.订阅MySQL binlog
利用 binlog 表监听及时发现,发现后就能集中处理,而且无论是在什么系统什么位置去更新数据,都能做到集中处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值