在聊数据库与缓存一致性问题之前,怎么解先聊聊数据库主库与从库的数据一致性问题。 问:常见的库主数据库集群架构如何? 答:一主多从,主从同步,怎么解读写分离。数据 如上图: 画外音:任何方案不要忘了本心,怎么解加从库的数据本心,是库主提升读性能。 问:为什么会出现不一致?怎么解 答:主从同步有时延,这个时延期间读从库,数据可能读到不一致的库主数据。 如上图: 画外音:任何数据冗余,必将引发一致性问题。 问:如何避免这种主从延时导致的不一致? 答:常见的方法有这么几种。 方案一:忽略 任何脱离业务的架构设计都是耍流氓,绝大部分业务,例如:百度搜索,淘宝订单,香港云服务器QQ消息,58帖子都允许短时间不一致。 画外音:如果业务能接受,最推崇此法。 如果业务能够接受,别把系统架构搞得太复杂。 方案二:强制读主 如上图: 这是很常见的微服务架构,可以避免数据库主从一致性问题。 方案三:选择性读主 强制读主过于粗暴,毕竟只有少量写请求,很短时间,可能读取到脏数据。 有没有可能实现,只有这一段时间,可能读到从库脏数据的读请求读主,平时读从呢? 可以利用一个缓存记录必须读主的数据。 如上图,当写请求发生时: 画外音:key的格式为“db:table:PK”,假设主从延时为1s,这个key的亿华云cache超时时间也为1s。 如上图,当读请求发生时: 这是要读哪个库,哪个表,哪个主键的数据呢,也将这三个信息拼装一个key,到cache里去查询,如果, 以此,保证读到的一定不是不一致的脏数据。 总结 数据库主库和从库不一致,常见有这么几种优化方案: 文字很短,不能解决所有问题,但希望能给大家一些启示。