【转载】小小的公共库,大大的耦合,你痛过吗?

【转载】小小的公共库,大大的耦合,你痛过吗?

什么是耦合?

耦合,是架构中,本来不相干的代码、模块、服务、系统因为某些原因联系在一起,各自独立性差,影响则相互影响,变动则相互变动的一种架构状态。

感官上,怎么发现系统中的耦合?

作为技术人,每每在心中骂上下游,骂兄弟部门,“这个东西跟我有什么关系?为什么需要我来配合做这个事情?”。明明不应该联动,却要被动受影响,就可能有潜在的耦合。

因为公共库,导致相互受影响,就是一个耦合的典型案例。

场景还原

一个看似“公共”的业务库(*.so *.jar *.dll *.php),很多业务系统都依赖于这个公共库,这个库使得这些系统都耦合在了一起。

注:这里的公共库不是指像“字符串操作”这样的不变化的工具库,更多是指通用业务的公共库。

耦合如何导致相互影响?

业务1,业务2,业务3都依赖于某一个biz.jar,业务1因为某个需求需要升级biz.jar。上线前,业务1的QA进行了大量的测试,确保无误后,代码发布,发布完线上验证无误后,上线完成,闪人。

突然,bug群里有人反馈,业务2的系统挂了,业务3的系统也挂了,一下炸开了锅:

  • 业务2的大boss首先发飙:“技术都干啥了,怎么系统挂了”

  • 业务2的rd一脸无辜:“业务1上线了,所以我们挂了”

额,然而,这个理由,好像在大boss那解释不通…

  • 业务2的大boss:“业务1上线?业务1上线前测试了么”

  • 业务1的qa自信满满:“测试了呀,上线前上线后都验证了,没问题呀”

  • 业务2的大boss对业务2的rd吼道“还想甩锅,拖出去祭天”

0490188453afd1773b1a0cbf5870f9f3

不知道大家工作中会不会遇到这样的场景,因为公共库的耦合,兄弟部门上线,影响的确是你,此时你心里可能就在骂娘了,这帮不靠谱的**队友。

特别的,如果公共库的使用方很广,这个耦合很严重,可能影响很大的范围。

如何解除公共库耦合?

方案一:代码拷贝一份

别嘲笑这个方案,谁敢说自己写代码的时候没这么干过?

我们都知道这不是一个好的方案,但不可否认,拷贝之后,代码各自演化,一个地方升级出错,只影响一方,拷贝方只要不动原有代码,至少是不会受影响的。

代码拷贝缺点很多,系统拆分时,万不得已不要使用这个方案。

方案二:垂直拆分,将公共库里业务个性化的代码拆到调用方去,不要放在公共库里

0ef4ebb1b8abb072fff73c5878a04c57

需要把业务个性的代码拆分到各个业务线自己的工程,自己的业务库里去,例如s1.jar / s2.jar / s3.jar,修改各自的代码,至少不会扩大影响范围。

大家为什么都把代码往一个公共库里塞?

很多时候,因为惰性,一点一点的惰性,日积月累,终成大坑。

这个垂直拆分是一个架构重构的过程,需要各业务方配合。

方案三:服务化,将公共库里通用业务代码拆到下层去

ac690839ee367bd7636e32a0c4adff7e

完成了第一步,业务个性化的代码提取到业务侧上游。

接下来是第二步,业务通用的代码,下沉抽取一层服务,服务对上游提供RPC接口:

  • 每次修改底层接口,需要测试接口的兼容性,保证不影响旧调用方

  • 如果是新的业务,则建议新增接口

最终,达到通过服务RPC调用的方式来解除耦合。

有朋友会问:

  • 底层服务接口的测试

  • 上游业务层对公共库的测试

都是测试,为何前者能控制影响范围呢?

  • 底层接口,所有人调用,接口没问题则调用方都没问题

  • 上游业务层对公共库测试,只能保证自己的业务没有问题,并不能保证其他业务方没有问题

个性业务代码上浮,共性业务代码服务化下沉,只是一个很小的优化点,但对于公共库解耦却是非常的有效。

希望大家每天收获一点点,这样架构就能美好一点点。

别人上线,你的系统挂了,痛过吗?那帮转下。

 

【转自】58沈剑 架构师之路

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119332.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C#中Dock属性的作用[通俗易懂]

    C#中Dock属性的作用[通俗易懂]当在C#项目开发中,在窗体界面的设置经常用到Dock属性值。这里一panel面板的Dock属性值为例描述其作用。当容器中的控件的Dock属性设置为Fill时,可能会覆盖其他Dock属性为Top,Bottom,Right,Left的控件。为了避免出现覆盖现象,可以将被覆盖的控件置于底层就可以(在panel面板上“右键”–“置于底层”),如下图所示。应用Dock时,越是底层的控件,其优先级越高。

    2025年10月28日
    4
  • 苹果x充电慢是什么原因_iPhone 12支持15W MagSafe无线充电,未来苹果手机的充电会发生什么?_充电器…

    2020-10-2122:44:400点赞0收藏0评论2020年由于一些特殊的原因导致一切似乎都和平时不一样了,所有的发布会都改成了线上,而备受关注的苹果也将发布会转移到了线上并采用录播的形式播出,从WWDC2020开始,我们就看到了一个不一样的线上发布会。众所周知,每年的秋季苹果都会发布新iPhone。在2020年9月份的苹果发布会上我们只见到了新iPad和新的AppleWatch发布,有且…

    2022年4月7日
    61
  • django url标签_正确的url格式

    django url标签_正确的url格式前言当我们访问网页的时候,后台返回列表中有n条数据,此时我们会使用分页,比如一页只展示10条,但是我们访问第一页的时候大多数情况下,都会给url一个默认值,访问的时候直接展示第一页数据案例我们的

    2022年7月28日
    6
  • 公钥密钥加密原理

    公钥密钥加密原理转载自:https://www.jianshu.com/p/0bf1c3c047e5第6章网络编程与网络框架2018.02.2523:22:49字数14531阅读1236.1公钥密钥加密原理6.1.1基础知识密钥:一般就是一个字符串或数字,在加密或者解密时传递给加密/解密算法。 对称加密算法:加密和解密都是使用的同一个密钥。因此对称加密算法要保证安全性的话,密钥要…

    2022年5月30日
    48
  • 关于权限表的基本设计[通俗易懂]

    关于权限表的基本设计[通俗易懂]对于一个系统,必须严格的控制权限,权限表的设计是基本的。基本的权限表有五个,即用户表,角色表,权限表,用户角色表,角色权限表。下面介绍下基本字段用户表  useruser_iduser_namepassword角色表  role role_idrole_name权限表 permissionpermission_idpermission用户角色表 

    2022年9月27日
    1
  • 《大话数据结构》电子版多看阅读独家上线[通俗易懂]

    《大话数据结构》电子版多看阅读独家上线[通俗易懂]经过了漫长的制作过程,《大话数据结构》电子版终于在多看阅读独家上线http://www.duokan.com/book/44279电子版本修正了目前已知的所有错误,可以在各种平板和智能手机上阅读,不过由于图和代码较多,建议使用平板电脑阅读效果更佳。 …

    2022年6月24日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号