为什么微服务并不是越早越好? 2024-08-04 14:16:28 微服务架构,是分层架构演进过程中很重要的一环,那微服务是不是越早越好呢?今天和大家一起聊聊这一个问题。 什么时候进行DAO层的分层抽象? 最开始,分层架构长什么样? 一个业务系统最初的分层架构如上:(1)web-server层从db层获取数据并进行加工处理;(2)db层存储数据;此时,web-server层如何获取底层的数据呢?web-server层获取数据的一段伪代码如上,不用纠结代码的细节,也不用纠结不同编程语言与不同数据库驱动的差异,其获取数据的过程大致为:(1)创建一个与数据库的连接,初始化资源;(2)根据业务拼装一个SQL语句;(3)通过连接执行SQL语句,并获得结果集;(4)通过游标遍历结果集,取出每行数据,亦可从每行数据中取出属性数据;(5)关闭数据库连接,回收资源;如果业务不复杂,这段代码写1次2次还可以,但如果业务越来越复杂,每次都这么获取数据,就略显低效了,有大量冗余、重复、每次必写的代码。如何让数据的获取更加高效快捷呢?通过技术手段能够实现:(1)表与类的映射;(2)属性与成员的映射;(3)SQL与函数的映射;绝大部分公司正在用的ORM,DAO等技术,就是一种分层抽象,可以提高数据获取的效率,屏蔽连接,游标,结果集这些复杂性。于是,分层架构就演进了。当手写代码从DB中获取数据,成为通用痛点的时候,就应该分层抽象出DAO层,简化数据获取过程,提高数据获取效率,向上游屏蔽底层的复杂性。 然后呢? 抽象出DAO层之后,系统架构并不会一成不变:(1)随着业务越来越复杂,业务系统会不断进行垂直拆分;(2)随着数据量越来越大,数据库会进行水平切分;(3)随着读并发的越来越大,会增加缓存降低数据库的压力;于是系统架构变成了这个样子:业务系统垂直拆分,数据库水平切分,缓存这些都是常见的架构优化手段。此时,web-server层如何获取底层的数据呢?根据楼主的经验,以用户数据为例,流程一般是这样的:(1)先查缓存:先用uid尝试从缓存获取数据,如果cache hit,数据获取成功,返回User实体,流程结束;(2)确定路由:如果cache miss,先查询路由配置,确定uid落在哪个数据库实例的哪个库上;(3)查询DB:通过DAO从对应库获取uid对应的数据实体User;(4)插入缓存:将kv(uid, User)放入缓存,以便下次缓存查询数据能够命中缓存;如果业务不复杂,这段代码写1次2次还可以,但如果业务越来越复杂,每次都这么获取数据,就略显低效了,有大量冗余、重复、每次必写的代码。特别的,业务垂直拆分成非常多的子系统之后:(1)一旦底层有稍许变化,所有上游的系统都需要升级修改;(2)子系统之间很可能出现代码拷贝;(3)一旦拷贝代码,出现一个bug,多个子系统都需要升级修改;不相信业务会垂直拆分成多个子系统?举两个例子:(1)58同城有招聘、房产、二手、二手车、黄页等5大头部业务,都需要访问用户数据;(2)到家集团有月嫂、保姆、快狗打车、蓝服等多个业务,也都需要访问用户数据;如果每个子系统都需要关注缓存,分库,读写分离的复杂性,调用层会疯掉的。如何让数据的获取更加高效快捷呢?服务化,数据服务层的抽象势在必行。通过抽象数据服务层:(1)web-server层可以通过RPC接口,像调用本地函数一样调用远端的数据;(2)数据服务层,只有这一处需要关注缓存,分库,读写分离这些复杂性;于是,分层架构就又演进了。当业务越来越复杂,垂直拆分的系统越来越多,数据库实施了水平切分,数据层实施了缓存加速之后,底层数据获取复杂性成为通用痛点的时候,就应该抽象出数据服务层,简化数据获取过程,提高数据获取效率,向上游屏蔽底层的复杂性。那微服务是不是越早越好呢?互联网分层架构是一个很有意思的问题,服务化的引入,并不是越早越好:(1)请求处理时间可能会增加;(2)运维可能会更加复杂;(3)定位问题可能会更加麻烦;千万别鲁莽的在“微服务”大流之下,草率的进行微服务改造,看似“高大上架构”的背后,隐藏着更多并未接触过的“大坑”。还是那句话,架构和业务的特点和阶段有关:一切脱离业务的架构设计,都是耍流氓。架构师之路 架构师之路,坚持撰写接地气的架构文章585篇原创内容公众号相关推荐:《InnoDB并发如此高,原因竟然在这?》《InnoDB索引,终于懂了》《InnoDB,调试死锁的方法!》 赞 (0) 相关推荐 微服务架构设计实践系列之九:应用架构 微服务架构设计实践 目 次1 序言2 微服务3 软件架构设计思想4 微服务架构设计实践4.1 项目概述4.2 架构准备阶段4.3 概念架构阶段4.4 细化架构阶段4.4.1 业务架构4.4.2 ... 服务8.6亿城镇人口16万个社区,智慧社区江湖风起云涌,谁的机会来了? 导 读 在各行各业都在积极推进智能化转型的当下,智慧社区经历疫情洗礼后也有望进一步加速推进,各类智能化.数字化技术方案或将成为社区标配. 智慧城市在中国有多火?自2012年中国智慧城市建设大幕正式拉 ... 阿里巴巴的幕后“台”前:用平台起家,靠平台管家 阿里巴巴的幕后“台”前:用平台起家,靠平台管家 培养孩子独立入睡越早越好,父母轻松,孩子也少遭罪 邻居家的宝妈抱怨:自己家的4岁的娃,每天晚上都喜欢让家长讲故事到很晚,或者是要玩玩具,总之每天晚上都要很晚才能够入睡.宝爸和宝妈都要上班,因为熬夜陪娃好多时候在第二天的工作中都没有精神.邻居家的妈妈特 ... 每天坚持这3件事,语文成绩蹭蹭涨!孩子知道越早越受益 小语说: 虽然语文是一门大科,占分比重大,可是语文又是提分效果最不明显的一科,很多孩子在语文方面下的功夫又少.不过,再困难的事情也是有方法的,学好语文都有哪些方法呢?今天小语给大家总结了一些经验与大家 ... 『女性健康』孕期保健越早越好 正常情况下,怀孕开始于末次月经后两周左右,此时只是一个受精卵,然后逐渐分裂.分化,发育成一个有头.躯干.四肢.五官及绝大部分脏器俱全.初具人形的胎儿.在此期间如遇见异常就可能使胎儿发育迟缓或停滞而致畸 ... 宝宝学走路越早越好?走路太早除了能“显摆”,坏处一大堆 有了孩子以后,你就会知道孩子会说话.会走路,都是你在妈妈圈聊天时可以显摆的事儿.不信,你可以推着婴儿车,带着孩子去小区公园试试,肯定很多人问你:"孩子多大了啊?会走路了吗?" 无论 ... 识字越早越多孩子越聪明?脑科学专家和牛校老师谈识字的真相 识字越早越多孩子越聪明?脑科学专家和牛校老师谈识字的真相 原创常青藤爸爸2021-02-19 13:00:00 下面这两个场景是不是很熟悉? 在生活中,如上面插画中有同样遭遇.同等困惑.同级焦虑的爸妈 ... 五一节前,老同学送上最美的节日祝福!越早越好! [老同学 Old classmates]版权声明 图文综合来自网络版权归原作者所有,如有侵权联系删除 「老同学」M先生综合编辑 五一节前老同学送上最美的节日祝福 (放到你圈子里,朋友们会感激您) ▲温 ... 为什么刑事案件请律师越早越好 刑事案件,有很多误区.包括律师.当事人和家属都存在许多根深蒂固的误区.刑事案件一般都会依次经历公安侦查.检察院审查起诉.法院审判这三个阶段.很多当事人和家属都认为到了法院请律师才有效果,毕竟案子是法院 ... 冠心病患者知道的越早越好的一件事,患者需... 冠心病患者知道的越早越好的一件事,患者需尽可能快的进行中医中药的辅助治疗. 为什么要这么说? 大多数人可能对冠心病不是特别的了解,对它的映像大抵上就仅限于是心脏病的一种吧,可随着近些年来,冠心 ... 针灸治疗面瘫应越早越好! 病因病机 中医观点:<灵枢·经筋>云:"卒口僻,急者目不合,热则筋纵,目不开,颊筋有寒,则急引颊移口:有热则筋弛纵缓不胜收,故僻",可见,面瘫主要是因面部脉络受损或痹阻 ...