生命以负熵为生。——薛定谔《生命是什么》
历史上有很多科学家为之背书的熵增定律,揭示了很多自然界现象的本质:任何孤立系统,在没有外力作用的情况下,其总混乱度(熵)会不断增大。
软件系统当然也不例外,随着软件系统的功能不断增加,系统的混乱度也在不断增大。为了降低软件系统混乱的速度,必须要对其施以外力(重构)。
重构系统和重构代码一样,首先要先识别系统的坏味道,Davide Taibi和Valentina Lenarduzzi在文章《On the Definition of Microservice Bad Smells》中定义了微服务的坏味道,今天我们就来聊聊如何消灭其中的一个坏味道——循环依赖。
循环依赖的危害
微服务之间的循环依赖类似于类之间的循环依赖,当依赖关系形成了环,会有很多危害:
首先是微服务之间的耦合性非常强,服务很难做到独立部署,这严重违反了微服务的初衷;这种情况往往是服务之间的调用没有约束导致的,为了方便取到或更新数据,服务之间可以随意的调用,以”微服务“为设计目标的系统会逐渐演变成一个分布式大单体,下图展示了三个服务之间的循环依赖关系:
另外循环依赖很可能导致一些循环调用或并发问题&