白话中台番外篇:DDD、EventStorming与业务中台(转载)

本文转载自(https://zhuanlan.zhihu.com/p/120896743

提到中台(尤其是业务中台)的构建方法论,就不得不提另两个同样伴随着微服务和中台概念兴起的工具:Domain-Driven Design(DDD,领域驱动设计)和EventStorming(事件风暴)。在各种讲中台落地规划,尤其是业务中台的共性能力识别和微服务划分的时候,总是能看到这两位的身影。不过相信好多朋友对于这两个相对陌生的面孔还是感觉云里雾里,搞不清楚到底是什么,以及与中台的关系。

本篇就以我个人的经历和视角,为大家讲述一下我对这二位的理解。

DDD(领域驱动设计)

回想一下,第一次接触DDD应该还是十多年前,那还是每天刷着JavaEye,看一群神仙打架的年代。

依稀记得那时候社区里讨论的最热的也还是Hibernate和OR-Mapping,RoR也还在蓄势待发,记忆中那也是我最开始接触DDD的时候。

所以,现在很多人以为DDD是个新冒出来的东西,其实并不是,这东西已经有了10多年的历史了,豆瓣上还有第一版领域驱动设计的蓝色版本的封面(不知道谁还有这个版本,反正我的是早就丢了)。而第一版的出版年份被定格在2006年3月1日,距今已经过去了13年。

img

DDD虽然诞生的早,但直到现在,和我们日常工作的距离也并不远,例如我们代码中经常出现的XxxEntity,XxxRepository ,XxxService,XxxFactory……这些类,这里的Entity、Repository、Service和Factory,以及我们现在大家早已习以为常的分层架构,都是出自DDD之手,只不过很多人已经不知道这些都是拜DDD所赐而已。

我们中的大多数人就像“猴子定律”里后来的猴子们一样,习惯了约定俗成,日复一日重复着(Controller-Service-Repository-Entity => CRUD)这些看似枯燥的操作,而早已忘了为什么一开始架构和这些所谓的最佳实践被设计成这个样子,少了一份溯本求源的精神。

以致于我经常在面试的时候,问候选人,你这里为什么要一个Service呀?大多数的回复都是:这是规范呀!这不是基本常识么?我们公司规定都得这么写的……

那说来说去,DDD到底是什么呢?

在我看来,DDD其实就是面向对象的一套“方言”,提供了一种基于业务领域的对象划分和分类方法,其最大的价值就在于对于软件开发过程全生命周期使用语言的统一!

怎么讲呢?

在面向对象的世界,只告诉了我们万事万物皆是对象。但并没有告诉我们对象究竟应该怎么组织,该以什么角度进行划分。

而作为技术人员的我们,早已习惯了从技术的角度出发思考,自然就出现了“用技术的语言”定义对象的习惯,例如最常见的DAO(Data Access Objects),DTO(Data Transfer Object)这类对象的划分方式就是使用技术视角看待和分类对象的典型案例。

这样从技术视角分类对象的问题,就在于在软件的开发过程中,会涉及到多“语言”间的对应和翻译,例如最常见的就是业务语言和技术语言的相互翻译。想想周围经常出现的研发和产品之间各种痛苦的沟(吵)通(架)场景,应该就知道我说的意思了。

这个过程其实和两种不同语言(例如中文和英文)的人之间的沟通是一样的,而且更加隐蔽,因为说的明明都是中文,但是彼此就是听不懂彼此说的到底是什么意思,而且都觉得对方像个傻子,听不懂人话,殊不知其实两个人说的本身就不是同一种语言。

而DDD的出现,就是为了解决这个问题。它通过一套面向对象的分类方法或是方言体系,从领域出发,实现软件开发过程中各个角色和环境的“统一语言”(UBIQUITOUS LANGUAGE)。例如使用“仓库(Repository)”替代“数据访问对象(DAO)”,就更能让业务和技术同时理解这个对象的作用。

就像车同轨,书同文一样。

好了,了解了DDD的来历和价值,那你肯定还有疑问,既然DDD这个概念已经快被人们淡忘了10多年了(虽然我们一直还在不知不觉中僵硬地应用着),那为什么最近一两年又突然重出江湖,重新被大家关注了呢?

答案其实就两个:微服务和中台

说到这里还有个段子:

其实DDD一开始的时候,就把领域分析设计分为了战略(Domain、Bounded Context)和战术(Entity、VO、Repository、Service……)两个部分。按道理应该从战略入手,再下沉到战术部分。但是Eric Evans在写《Domain-Driven Design》这本书时,可能是基于当时的环境,却是先写的战术部分,书的后半部分才开始展开DDD的战略部分。

而又因为战术部分本身就很复杂很枯燥(各种图各种代码),所以很多人并没有坚持到读后边的战略部分,就读不下去(比如我)。导致的结果就是这么多年战术部分被大家充分的讨论和应用,而战略部分的影响则相较之下非常有限,讨论和应用的也不多。

img

直到微服务的横空出世……

随着微服务架构的兴起,微服务到底如何拆分就成了人们最最关注的问题。这时候一些“老人儿”们突然想起来,这不是正是应用DDD中战略部分(问题域,限界上下文)应用和施展拳脚的场合么?!

所以随着微服务的爆炸式发展,DDD这位退隐已久的老江湖,又再次被请出了山,站到了大家的面前。

而此时,他身边还多了一个年轻的新搭档,他正是:事件风暴。

EventStorming(事件风暴)

现在,当很多人谈到DDD都会同时谈到EventStorming,甚至有人误认为这两个名词本身指代的就是同一个概念。

但其实这是两个完全独立的工具。

DDD是一套基于领域的分析和建模方法,而EventStorming则是一套Workshop(可以理解成一个类似于头脑风暴的工作坊)方法。DDD出现要比EventStorming早了10多年,而EventStorming的设计虽然参考了DDD的部分内容,但是并不是只为了DDD而设计的,是一套独立的通过协作基于事件还原系统全貌,从而快速分析复杂业务领域,完成领域建模的方法。

img

EventStorming最初由Alberto Brandolini(曾受邀参加了DDD-China 2017)开发,经过DDD社区和ThoughtWorks的很多团队实践验证后,于2015年11月进入ThoughtWorks技术雷达,开始被更多人知晓和应用,从此成为DDD的最佳拍档。

img

关于EventStorming的具体内容和细节,已经有很多文章都介绍了,不过还是强烈建议先看一下http://eventstorming.com 官网的那本作者Alberto Brandolini自己写的《Introducing EventStorming》,应该是最官方最正宗的对于EventStorming的介绍。

而书中的下面这个图,我认为是对于EventStorming最清晰、完整且简单的概括。完整的阐释了从系统外部与用户的交互,到系统内(事件-策略-命令-聚合-事件)的事件传递涟漪,以及通过事件影响到读模型从而给予用户动作的响应,从而形成完整闭环的全过程。对我们了解还原系统的全貌非常有帮助。

img

前面提到了,EventStorming和DDD两个独立的工具,形式不同、解决的也是不同的问题,那为什么这两者总是搭档出现呢?

关键就在于下图这条红线,就像是月老手中的红线一样,将两个概念牵在了一起。

DDD提供了一套面向对象的“方言”,给出了一套面向对象的分类框架和架构指引,但是在DDD中并没有明确给出如何为一个系统识别出这些不同种类的对象的过程和方法。

而EventStorming的出现正好弥补了这个空白,通过EventStorming工作坊的方式,正好给我们提供了一个还原和分析系统的方法,并最终通过“聚合”这条红线,穿越时空,无缝切入到DDD的领域范畴之内,以“聚合”为支点,向上可以进一步做问题域和限界上下文的战略分析,向下则可以通过聚合的进一步展开进行实体、值对象等相关的战术分析,引导落地。

img

而DDD战略设计中问题域和限界上下文的识别,则为我们划分微服务提供了非常强有力的支撑,至此我们就通过EventStorming和DDD的这一对强力组合的联袂辅助下,找到了解决了微服务架构下最困难问题之一的,既服务该如何划分问题的解题思路和落地方法。

那说了半天微服务,DDD和EventStorming到底又与业务中台有什么关系呢?

DDD、EventStorming与业务中台

我之前的文章曾提到过业务中台与微服务的关系,而当时我的观点很简单,就是:没有直接关系。

业务中台解决的是企业级能力复用的问题,而微服务解决的是运行时解耦的问题。业务中台不一定是微服务的,采用微服务架构的也不一定就是业务中台,这些之前都提到过,这里就不赘述了。

所以很多人以为使用DDD和EventStorming规划业务中台,是因为微服务,在我看来,基于以上的分析这也是站不住脚的,难道我不用微服务架构来实现业务中台,就无法使用DDD和EventStorming了么?

DDD和EventStorming的结合,形成的是一套“领域分析方法”,可以想象成一套双剑合璧的剑阵。其目的是透过现象看本质,透过表面的业务流程来分析背后的核心领域问题和概念,而微服务架构只是使用了这套能力,来指导和帮助进行服务划分而已,并且也不是唯一的指导原则,其他还需要考虑像团队组成、变更频率、技术异构边界、SLA要求等等因素……

而对于业务中台,这套领域分析方法,则可以指导我们探究与分析业务中台规划过程中的一个最困难的问题,既:识别不同的业务线,到底有哪些业务是可以复用的?

因为如果只分析表面的功能和流程,我们总是会发现虽然不同的业务看似都差不多,但总是有不同的地方,很难抽取共性。

这就像我们看每个人,乍一看都长得差不多,一个脑袋一个身子,俩个胳膊俩条腿。但是仔细观察,又会发现每个人都是不一样的,细节上还是有很大的差别,长相不同,性格不同,做事方式也不一样。

而领域分析就像是给人照个B超一样或是做一个性格分析一样,透过外表和行为,分析背后的本质和机理,寻找不同背后的相同,找寻变化背后的不变。

而这种通过领域分析和抽象,找寻不同业务线背后面对的相同的问题域,并从中提取共性的业务模型、提取共性的业务功能、提取共性的业务流程、甚至是提取共性的业务模式,加工并予以复用的过程,也正是业务中台的规划与建设过程的关键所在。

img

这也是为什么当我们提到业务中台规划的时候,总是会涉及到DDD和EventStorming,并把他们作为核心方法的原因。

总结

最后,我们用武侠小说中的一段场景来收尾做个总结:

江湖上流传着一个人的传说:
十年前,他一身白衣飘飘,仗双剑叱咤江湖,但只用一剑,已天下无敌,从来没有人看到过他的另一把剑出鞘。
十年间,江湖上早已不见了白衣人的踪迹,人们虽然还在不断地传承着这流传下来的无名剑法,但忘已忘却了这个剑法背后的那个人。
十年后,江湖又是一场大乱,白衣人又重现江湖,虽然已没有几个人认识他,但是认识的人看到他之后都无不大吃一惊。
这十年,他的容貌没有一点变化。
但让人吃惊的不是他的容貌,而是他的剑:此时,双剑都已出鞘!
而他的身旁,还站着另一个持剑的少年,一样的白衣飘飘,一样的冷峻与潇洒,让人们不禁想起了白衣人十年前的样子。
两个人,三把剑,一套剑阵,能否能平息这场江湖大乱?
或是否还会有其他的英雄会横空出世?
棋至中盘,一切都还未成定论,让我们一起拭目以待!

文/ThoughtWorks 王键