请你谈谈Redis数据不一致问题?

1为什么会出现不一致?

主从同步有延时,延时期间读从库,可能读到不一致的数据。
在这里插入图片描述
1)服务发起了一个写请求;
2)服务又发起了一个读请求,此时同步未完成,读到一个不一致的脏数据;
3)数据库主从同步最后才完成。

2如何避免这种主从延时导致的不一致?

方案一:忽略

任何脱离业务的架构设计都是耍流氓,绝大部分业务,例如:百度搜索,淘宝订单,QQ消息,58帖子都允许短时间不一致。画外音:如果业务能接受,最推崇此法。如果业务能够接受,别把系统架构搞得太复杂。

方案二:强制读主

在这里插入图片描述
1)使用一个高可用主库提供数据库服务;
2)读和写都落到主库上;
3)采用缓存来提升系统读性能。
这是很常见的微服务架构,可以避免数据库主从一致性问题。

方案三:选择性读主

只有这一段时间,可能读到从库脏数据的读请求读主,平时读从呢?

可以利用一个缓存,记录必须读主的数据。
在这里插入图片描述
1)写主库;
2)将哪个库,哪个表,哪个主键三个信息拼装一个key设置到cache里,这条记录的超时时间,设置为“主从同步时延”。画外音:key的格式为“db:table:PK”,假设主从延时为1s,这个key的cache超时时间也为1s。
在这里插入图片描述
这是要读哪个库,哪个表,哪个主键的数据呢,也将这三个信息拼装一个key,到cache里去查询,如果,
1)cache里有这个key,说明1s内刚发生过写请求,数据库主从同步可能还没有完成,此时就应该去主库查询;
2)cache里没有这个key,说明最近没有发生过写请求,此时就可以去从库查询。
以此,保证读到的一定不是不一致的脏数据。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值