事件驱动微服务边界定义与领域驱动设计
1. 事件驱动微服务边界组织
事件驱动的微服务彼此高度解耦,这使得我们可以在不影响其他服务的情况下对单个服务进行更改和部署。这种独立更改和部署的能力对于支持快速增长和发展的业务至关重要。然而,随着系统的不断发展,复杂性会阻碍我们实现高度进化和解耦的架构。因此,组织和定义不断增加的服务之间的边界成为了一个主要问题。
事件驱动架构由于使用事件作为通信形式和事实来源,具有高度解耦的特性。但随着系统变得更加复杂,我们不能想当然地认为这种解耦特性会一直保持。即使通过消息队列实现了解耦,如果我们需要反复添加跨越多个服务的功能,这些服务往往会相互依赖于彼此的更改,这很容易导致多个服务需要等待其他服务的更改才能发布,形成发布僵局,并且凸显出复杂服务网络之间的复杂依赖关系。
定义微服务边界有多种方法,一个实用的经验法则是:一起更改的代码放在一起。采用领域驱动的方法来解构系统是一种合理的边界定义方式。领域通常比其他方法更稳定,以公司的领域为出发点定义的边界,更能适应变化,而不会将变化传播到整个架构中。通过围绕领域划定边界,既为领域的发展提供了空间,又能限制对其他领域的影响。这种方式也与公司的组织架构有很好的相关性,团队通常围绕领域概念进行安排,这与围绕这些领域设置边界的架构相契合。
除了领域驱动方法,还有其他组织边界的方法,定义边界和确定新功能的归属通常是多种方法的结合。我们要明白,定义边界并非只有一种方式,领域方法是一个合理的选择,但不是唯一的方式,结合多种方法往往能带来更多好处。
以下是几种常见的定义微服务边界的方法:
| 方法 | 说明 | 优点 | 缺点 |
| ---- | ---- | --
超级会员免费看
订阅专栏 解锁全文
176万+

被折叠的 条评论
为什么被折叠?



