【按】“DDD诊所”是Thoughtworks DDD社区的一项活动,通过对同事们在实施DDD过程中遇到的问题进行分析和解答,共同提高开发水平。我们将其中一些典型案例整理成文供大家参考。之后也会考虑在适当的时候将这一形式对外部开放。
就诊日期:2021年11月1日
患者:某零部件管理系统
诊金:0元(免费义诊)


患者的病情还是比较复杂的,需要几个方面的综合治疗。但这次就诊时间有限,于是医生首先询问了患者的监护人,哪个问题是最紧迫的。监护人认为是异步事件机制。所以这次集中分析这个问题。(为了讨论方便,本文假定微服务和限界上下文是一一对应的,会将两者混合使用,不做区分。两者不一一对应的情况将在以后另文分析。)
“图1 当前系统架构”中有大量的MQ(消息队列),所以我们首先怀疑患者很可能过渡使用了异步事件。当然还需要通过进一步诊断来求证。
很多朋友知道,领域事件是DDD领域模型的重要组成部分,又看到很多大厂大量采用了异步机制来处理领域事件,而一些书上也强调了异步机制的使用,因此就认为采用异步机制处理领域事件是理所当然的。那么这种理解完全正确吗?让我们从头说起。
“领域事件是DDD领域模型的重要组成部分”这一点是完全正确的。事实上,在Evans 2003年的《领域驱动设计》一书中并没有提领域事件。但在DDD之后的发展过程中,很多专家指出了领域事件的重要性。在2015年,Evans又写了一本小册子“Domain-Driven Design Reference”简要总结了DDD中的各个模式,在其中增加了领域事件(Domain Events)。