在没缓存的情况下
1.当服务写完主库 2.有一个请求读取从库数据 3.主从同步完成 这时出现主从不一致(写后立即读)
处理方案 1.业务允许的情况,直接忽略 2.强制读主节点 3.选择性读主节点
有没有可能实现,只有这一段时间,可能读到从库脏数据的读请求读主,平时读从呢? 即在主从同步这段时间读取主节点,同步完成之后读取从节点
可以利用一个缓存记录必须读主的数据。
如上图,当写请求发生时: (1)写主库 (2)将哪个库,哪个表,哪个主键三个信息拼装一个key设置到cache里,这条记录的超时时间,设置为“主从同步时延” (key的格式为“db_table_PK”)
当读请求发生时: 这是要读哪个库,哪个表,哪个主键的数据呢,也将这三个信息拼装一个key,到cache里去查询,如果, (1)cache里有这个key,说明1s内刚发生过写请求,数据库主从同步可能还没有完成,此时就应该去主库查询 (2)cache里没有这个key,说明最近没有发生过写请求,此时就可以去从库查询以此,保证读到的一定不是不一致的脏数据。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有