在聊数据库与缓存一致性问题之前,先聊聊数据库主库与从库的一致性问题。
问:常见的数据库集群架构如何?
答:一主多从,主从同步,读写分离。
如上图:
画外音:任何方案不要忘了本心,加从库的本心,是提升读性能。
问:为什么会出现不一致?
答:主从同步有时延,这个时延期间读从库,可能读到不一致的数据。
如上图:
画外音:任何数据冗余,必将引发一致性问题。
问:如何避免这种主从延时导致的不一致?
答:常见的方法有这么几种。
方案一:忽略
任何脱离业务的架构设计都是耍流氓,绝大部分业务,例如:百度搜索,淘宝订单,QQ消息,58帖子都允许短时间不一致。
画外音:如果业务能接受,最推崇此法。
如果业务能够接受,别把系统架构搞得太复杂。
方案二:强制读主
如上图:
这是很常见的微服务架构,可以避免数据库主从一致性问题。
方案三:选择性读主
强制读主过于粗暴,毕竟只有少量写请求,很短时间,可能读取到脏数据。
有没有可能实现,只有这一段时间,可能读到从库脏数据的读请求读主,平时读从呢?
可以利用一个缓存记录必须读主的数据。
如上图,当写请求发生时:
画外音:key的格式为“db:table:PK”,假设主从延时为1s,这个key的cache超时时间也为1s。
如上图,当读请求发生时:
这是要读哪个库,哪个表,哪个主键的数据呢,也将这三个信息拼装一个key,到cache里去查询,如果,
以此,保证读到的一定不是不一致的脏数据。
总结
数据库主库和从库不一致,常见有这么几种优化方案:
文字很短,不能解决所有问题,但希望能给大家一些启示。
本文实例为大家分享了javascript实现数字时钟效果的具体代码,供大家参考,具体...
event.keycode值大全 1 keycode 8 = BackSpace BackSpace 2 keycode 9 = Tab Tab...
文章目录 算法效率 大O的渐进表示法规则 时间复杂度 空间复杂度 算法效率 算法效...
以前项目基本上全部使用MySQL数据库, 最近项目排期空出了一点时间leader决定把日...
目录 Delphi线程内部 unit System.Classes; unit System;? unit System.Threadin...
【51CTO.com快译】通常,诸如MySQL等时下流行的数据库管理系统(DBMS),都是由Web...
这篇文章底端的图为什么这么大……不管了 [--大家好我们第一个团本CD就通了PT而...
写在前面 上篇文章我给大家讲解了 ASP.NET Core的概念 及为什么使用它,接着带着...
今天,知名开源项目 Presto 的三位发起人宣布,将 PrestoSQL 项目的名字改为 Tri...
HTML设置边框的三种方式 文章目录 HTML设置边框的三种方式 1、边框的组成: 2、复...