歪读《架构整洁之道》第(12-14)章之组件构建原则

    我所在的项目在公司本身是以组件化开发著称,而我本身负责项目的组件集成,所以书中很多的观点可以说深有体会(本想说不谋而合的,哈哈)。

组件的定义

    作者认为组件是软件的部署单元,是整个软件系统在部署过程中可以独立完成部署的最小实体。比如,对于Java应用程序而言,Jar包就是组件;Ruby中的组件则是Gem文件;Python中的Egg或Wheel文件以及.Net下的DLL文件。

    当然,这里的jar包应该是把依赖的其它jar包等打包到自己的jar中(比如通过maven的maven-shade-plugin来实现),这样出来的jar包就是独立可部署的单元了。在实际的大项目中,每个jar包都只会打包自己的类,不会去包含依赖的jar包,否则底层jar包就会被多处包含,造成软件体积变大。单体程序如此,微服务架构也有类似的问题,虽然微服务的容器运行体积不会变大,但是我们在操作的时候会把公共的SDK打包为一个基础镜像,供上层组件制作应用镜像的时候进行依赖。所以一个jar包常常不能独立部署,甚至我们常规定义的组件也不能独立部署,而是提供一个独立的功能。

好的组件要求是高内聚,底耦合,那么组件的聚合与耦合该遵循什么原则呢?

组件聚合

作者就组件聚合,也就是哪些类应该被组合到一个组件,提出了三个原则:

REP(复用/发布等同原则):软件复用的最小粒度应该等同于其发布的最小粒度。

CCP(共同闭包原则):将会同时修改,并且为相同目的而修改的类放到同一个组件;不会同时修改,并且目的不同的类放到不同的组件

CRP(共同复用原则):不要强迫一个组件的用户依赖他们不需要的东西

精华汇聚成如下的组件聚合张力图,与CAP定理(指的是在一个分布式系统中,Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得)差不多,一个系统中,无法完全兼顾三个原则,关注某两个原则越多,对第三个原则损失也就越多。


组件聚合张力图

    我当前所在项目明显是更多注重REP和CCP,牺牲了CRP原则,这样造成的一个后果就是,我们会有一个较为庞大的基础组件,但应用组件达到了最小化。当这个基础组件不如预料那样稳定,而会频繁修改,就会造成所有应用组件都会需要重新编译、验证。当还频繁出现不兼容变更,影响就会更大些了,也就出现张力图最上面的“太多不必要的发布”的问题,这对我们持续集成的要求就非常高了。

组件耦合

    组件之间不可避免会出现依赖关系,依赖关系不同组件之间集合为一个大系统的必备条件。

    我负责的上一个项目,使用ant构建,很多组件耦合在一起进行编译,当某个组件依赖另一个组件编译的时候,直接采用拷贝或写死依赖路径的方法。这样每个组件完全没法独立编译,开发人员本地编译,通常需要对整个软件进行全量编译,完成后才可以对自己的代码进行修改编译。开发人员通常不会及时更新别的组件代码,也不会经常进行全量编译,造成明明本地编译可以通过的代码,项目集成全量编译还是经常编译不过。

    后来为了进行组件化编译,引用ant+ivy的方式进行依赖解耦,花了很大代价才完成改造,使得组件独立构建成为可能。

    所以依赖本身不能说好或者不好,作者在这里也提出了三个原则:

ADP(Acyclic Dependencies Principle 无依赖环原则):组件依赖关系图中不应该出现循环。

当前我们项目采用maven构建,nexus仓库进行制品管理,仓库的缓存造成同版本出现依赖循环也无法及时发现,这个在当前构建中需要通过切换版本号才会暴露出问题,而切版本一般都是临近版本发布集成时间点,这样经常会阻塞集成,且没有一个好的方法来提前发现。

SDP(Stable Dependencies Principle 稳定依赖原则):依赖关系必须要指定更稳定的方向。

该原则的核心就是被依赖多的,如我们常说的SDK,基础组件,需要更多的保持稳定性。作者提出一个稳定性指标:出向依赖(Fan-out)/(出向依赖(Fan-out)+入向依赖(Fan-int)),极端情况,Fan-out为0,即该组件完全不依赖其它组件,说明这个组件的稳定性指标高,反之,Fan-int为0,即完全没有组件依赖自己,那么组件稳定性指标差。

SAP(Stable Abstractions Principle 稳定抽象原则):一个组件的抽象化程度应该与其稳定性保持一致

这里是对第二点指标的补充,也就是说,并不是说组件稳定性指标差就是不好,相反,稳定性指标差的组件,有更多的修改是可以接受的,反而稳定性指标高的组件,被频繁修改,反而是不可接受的,这会造成一系列依赖组件的修改。


稳定抽象原则
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容

  • 序 程序员的三个层次(1) 普通程序员编写代码,能够让程序跑起来的人。(2) 工程师有“洁癖”、有工匠精神、有修养...
    nimw阅读 1,656评论 0 3
  • 组件耦合 上回说到组件聚合,反映的是组件内部的“基本元素”的选择标准。第14章介绍的组件耦合则是指组件和组件之间的...
    lambeta阅读 4,927评论 3 27
  • 目标 用最少的人力成本满足构建和维护该系统的需求 衡量指标 版本迭代——工程师团队规模 版本迭代——代码总行数 版...
    光剑书架上的书阅读 272评论 0 3
  • 最近读了《架构整洁之道》(https://u.jd.com/5nzQJQ) 这本书,这是由Bob大叔所写的一本关于...
    SCQ000阅读 862评论 0 0
  • 本文是《架构整洁之道》的读书心得,作者将书中内容拆解后再组织,不仅加入了个人的独到见解,而且用一张详细的知识脉络图...
    程序员小2阅读 208评论 0 1