微服务架构 (六): 微服务间的共享的管理

在微服务的架构下, 产品或许会有上百个或上千个微服务。因此, 当这些上百个或上千个微服务, 同时都依赖于某个库 (Library) 时, 则当此共享的库, 即便只是针对某个微服务作些不多量的修改, 也可能会对其余上百个或上千个微服务, 形成不可预期的影响。架构


但在实际的项目中, 产品中的微服务又没法避免的会对某些库 (Library) 产生依赖; 共享某些库 (Library)。运维


因此, 架构师必须要知道要如何管理微服务间的共享?ide


微服务会造成共享的缘由, 主要是来自于:微服务


1.       微服务共同继承于某个抽象的接口。单元测试


2.       微服务同时依赖于某个共享的库 (Library)。测试


架构师可采用如下的四种方案, 管理微服务间的共享:继承


A.      Compile Binding: 将多个微服务会共享的代码, 置入在一共享的项目中。在编译的时候, 共享的代码便与特定的微服务的代码编译在一块儿。此种方案, 从开发的角度, 其好处是显而易见的: 不需重启运维中的微服务, 而是在编译, 单元测试的时候, 特定的微服务即可当即知道, 在共享项目中的任何的修改或变动, 对微服务自身的影响为什么? 然而, Compile Binding 却存在著个严重的问题: 当共享的项目与数十个、上百个微服务是 Compile Binding 时, 则有的微服务可编译, 可测试经过, 可发布、有的微服务却发生了没法编译, 或测试不经过、有的微服务则发生了没法发布....; 真的是一场灾难。更糟糕的是, 当灾难发生时, 各个微服务也无法对所共享的项目, 有任何的选择权或控制权; 各个微服务没法选择自身所要的共享项目的版本。接口


B.      JAR File/ Shared Library: 各微服务间共享著编译, 构建后的包 (Shared Library) ; 如: JAR包。开发


此方案最大的好处即是: 各个微服务间对其所共享的 Shared Library 拥有所谓的选择权; 也就是说, 某个微服务可选择 1.0 版的 JAR, 另外一个微服务则能够选择 1.5 版的 JAR。固然, 缺点是: 当有数十个、上百个, 甚至是上千个微服务共享某个发生变动的 Shared Library 时, 则这些为数众多的微服务便得一一的从新启动后, 才能执行测试, 才能得知 Shared Library 的改变, 对各个微服务的影响。Share Library 应尽可能的能细分到某一特殊功能的粒度; 如: 某一庞大的 Backend.jar 应细分为 Persistence.jar, SQL.jar, Security.jar。某一大而全的 Utility.jar 亦应细分为Calculator.jar, MaxTime.jar。这样的细分粒度, 将有利于能更精确的分析出, Shared Library 在每一个版本中到底变动些了什么? 各微服务针对这些变动, 所应采起的相对应的措施为什么?产品


C.      Replication:将各微服务都会用到模块 (代码) , Copy-Paste 到各个微服务中。


此方案虽然违背了DRY (Do not RepeatYourself.), 但却使得每一个微服务维持了自身的边界上下文 (Bounded Context), 而使得产品中的数百个或甚至数千个微服务间的依赖下降; 产品中的数百个或甚至数千个微服务间的依赖越少, 各微服务便得以更高效的方式进行开发、测试、发布。


固然, 架构师必须要确保: Copy-Paste 到各个微服务中的模块 (代码) 的质量是稳定的与变动的频率是不高的。由于, 任何一个质量上的缺陷或任意的变动, 将会形成数百个或甚至数千个微服务维护的工做量。  


D.      Service Consolidation: 当某个SharedLibrary; 如: 某个.jar; 被多个微服务所共用时, 则当此 Shared Library 有变动时, 多个共用此 Shared Library 的微服务, 将必需再次的被测试, 再次的被发布。架构师此时应从新的思考: 这些共用 Shared Library 的微服务, 那些或所有可与 Shared Library 合并为一单一的微服务; 合并后, 将可减化 Shared Library 变动后的测试与发布的复杂度与工做量。

相关文章
相关标签/搜索