(2)多个从库提供读服务,可以增加从库提升读性能;
 画外音:任何方案不要忘了本心,加从库的本心,是提升读性能。
 主从同步有时延,这个时延期间读从库,可能读到不一致的数据。
 (2)服务又发起了一个读请求,此时同步未完成,读到一个不一致的脏数据;
 任何脱离业务的架构设计都是耍流氓,绝大部分业务,例如:百度搜索,淘宝订单,QQ消息,58帖子都允许短时间不一致。
 这是很常见的微服务架构,可以避免数据库主从一致性问题。
 强制读主过于粗暴,毕竟只有少量写请求,很短时间,可能读取到脏数据。
 有没有可能实现,只有这一段时间,可能读到从库脏数据的读请求读主,平时读从呢?
 (2)将哪个库,哪个表,哪个主键三个信息拼装一个key设置到cache里,这条记录的超时时间,设置为“主从同步时延”;
 画外音:key的格式为“
 db:table:PK
 ”,假设主从延时为1s,这个key的cache超时时间也为1s。
 这是要读哪个库,哪个表,哪个主键的数据呢,也将这三个信息拼装一个key,到cache里去查询,如果,
 (1)cache里有这个key,说明1s内刚发生过写请求,数据库主从同步可能还没有完成,此时就应该去主库查询;
 (2)cache里没有这个key,说明最近没有发生过写请求,此时就可以去从库查询;
 (3)在cache里记录哪些记录发生过写请求,来路由读主还是读从;