缘起
成都创新互联是一家集网站建设,文安企业网站建设,文安品牌网站建设,网站定制,文安网站建设报价,网络营销,网络优化,文安网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
在《服务读写分离(读服务,写服务),是否可行?》中,对背景做了交代,互联网架构设计上,数据库可以读写分离,服务能否读写分离呢?
下面是两种常见的“服务读写分离”架构:
一、单纯服务读写分离
如上图,服务化之后:
二、服务和数据库同时读写分离
读服务与写服务读写的是不同的数据库,如上图:
写库与读库是一个组从同步的集群。
这种架构设计好还是不好,网友进行了激烈的讨论,感兴趣的同学可以看下《服务读写分离(读服务,写服务),是否可行?》的评论,这里,分享下个人的观点。
三、先说结论
楼主旗帜鲜明的反对服务区分读写分离。
四、小理由
调用方对同一个基础服务,某一个RPC接口,在读服务,还是写服务,容易困惑
对于同一个基础服务,服务数量翻倍了,运维更加复杂
五、强理由
一般来说,垂直拆分,是按照“子业务”维度进行拆分,而不是按照“读写”维度进行拆分,这是模块化设计的基本准则。
1. 完全打破了“服务化数据库私有”的微服务初衷
两个服务因为同一份数据库资源访问而耦合在一起,当数据库资源发生变化的时候(例如:ip变化,域名变化,表结构变化,水平切分变化等),有两个依赖点需要修改。
而好的设计,有变化产生时,只有一个需要修改(低耦合,高内聚),前段时间的“耦合”系列文章,已经多次提到了这一点:
《小小的IP,大大的耦合》
《小小的公共库,大大的耦合》
《服务化了,耦合却更加严重了》
2. 没法很好的添加缓存
大部分互联网业务是读多写少的业务,数据库读取最容易成为瓶颈,常见提升读性能的方式是,增加缓存。
如上图,读服务的下游增加一个缓存,当有读请求访问时:
额,然后,这个架构中,这个方案是不可行的。
因为,写服务修改数据库时,缓存中的数据没有办法得到淘汰!!!
OK,有朋友说,写数据库之前,可以由写服务来淘汰缓存:
即,读服务与写服务都可以操作缓存。额,这个设计,又违背了“服务化缓存私有”的微服务初衷,两个服务因为同一份缓存资源访问而耦合在一起,当缓存资源发生变化的时候,有两个依赖点需要修改。
况且,如果真的两个服务访问相同的数据库和缓存,为什么不合成一个服务呢?
硬要拆成两个服务,不是自己玩自己么?
OK,有另外的朋友说,可以由写服务发消息来淘汰缓存:
如上图:
这种设计:
所以,还是一个服务更好:
六、结论
互联网微服务架构,应该按照“子业务”进行微服务拆分,而不应该按照“读写”来进行微服务拆分,避免过度设计。
【本文为专栏作者“58沈剑”原创稿件,转载请联系原作者】
当前文章:服务读写分离架构,绝不推荐
本文地址:http://www.gawzjz.com/qtweb2/news0/24900.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联