微服务坏味道之循环依赖

循环依赖在微服务架构中是一种常见的坏味道,它导致服务耦合性增强,难以独立部署。本文探讨了循环依赖的危害,产生的原因,如数据冗余、缺失业务概念和滥用同步调用,并提出了解决循环依赖的原则,包括定义服务上下游关系、使用领域事件和避免数据冗余等。通过识别和消除循环依赖,可以维护微服务架构的健康。
摘要由CSDN通过智能技术生成

生命以负熵为生。——薛定谔《生命是什么》

历史上有很多科学家为之背书的熵增定律,揭示了很多自然界现象的本质:任何孤立系统,在没有外力作用的情况下,其总混乱度(熵)会不断增大。

软件系统当然也不例外,随着软件系统的功能不断增加,系统的混乱度也在不断增大。为了降低软件系统混乱的速度,必须要对其施以外力(重构)。

重构系统和重构代码一样,首先要先识别系统的坏味道,Davide Taibi和Valentina Lenarduzzi在文章《On the Definition of Microservice Bad Smells》中定义了微服务的坏味道,今天我们就来聊聊如何消灭其中的一个坏味道——循环依赖。

循环依赖的危害

微服务之间的循环依赖类似于类之间的循环依赖,当依赖关系形成了环,会有很多危害:

首先是微服务之间的耦合性非常强,服务很难做到独立部署,这严重违反了微服务的初衷;这种情况往往是服务之间的调用没有约束导致的,为了方便取到或更新数据,服务之间可以随意的调用,以”微服务“为设计目标的系统会逐渐演变成一个分布式大单体,下图展示了三个服务之间的循环依赖关系:

另外循环依赖很可能导致一些循环调用或并发问题,造成一些复杂难以定位的问题,以上图中订单和客户的循环依赖为例:

订单服务依赖客户服务来获取客户信息,为了满足可以根据客户姓名查询订单的需求,除了记录客户的ID&#

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值