面向领域事件建模

        试考虑一个打算入手IPHONE X的90后白领,他计划在网上某电商平台入手,他未必对网站的建造细节感兴趣,技术的选型,实施的计划和许许多多关于工程细节的会议,对于平台建造者与运营方是很重要的活动,但对于平台买家来讲却远远没有那么重要。

        对于IPHONE X的买家关注的是花期望的价位,在期望的时间内收到货物,要保证他的购买是没有风险的。也不排除购买者完全信任这这个平台,在其付款后,在收到货物前完全不关注订单状态,这样的用户关注的是购买的最终状态。

        较为务实的买家仍是信任平台的,但也想在付款后持续关注他的订单是正确运作的。因此,审慎的买家不是给平台付款后就无人照管了,而是为购买过程设立明确的里程碑,每个里程碑对应着某一活动的完成,并且仅当里程碑在依次不断的突破后,买家才会认为他的订单在正确的处理过程中。

        接下来看一看,从买家下单到收到货物,这个过程中还会有哪些里程碑呢。这里把里程碑都命名了该工程的一个稳定状态:

        对于平台买家来讲,跟踪状态变化比跟踪活运流更为重要,这些活动流可能是平台开发人员用流程图对平台的工作流建模所做的。

        对于系统设计也一样,将发现可视化,详述,构造某些对象行为的最自然的方法是着眼于从状态到状态的控制流,而不是着眼从活动到活动的控制流。后者可以用流程来表示,对于前者,基于状态机为整个系统生命周期建模或基于DDD的领域事件为系统建模都是可行方案之一。对于状态机的应用,在UML的时代非常流行,作为高级建模技术,能够完成对象或整个系统的生命周期建模,但对于复杂系统的系统生命周期建模复杂度很高,只在特定领域中应用很普遍,像电信行业。随着DDD的兴起,业内更倾向面向领域事件建模来完成这部分工作,这方面《Event Storming》实操性很强并且可以快速落地。

        回到电商平台案例,上文已经识别出买家的关键里程碑,对于一个完整的系统应由多个角色协作完成业务价值。为多个不同的角色在不同场景下实别出关键里程碑开始,如果我们把系统所有相关角色的里程碑实别出来,并按时间顺序发布出去,结果如下图。

        特定领域中发生的一件事情称为领域事件,上图中的每个里程碑即是系统中的领域事件,从整个系统生命周期的领域事件入手本质上就是一种整体性的思考过程,要求我们用整体的观点观察周围的事物,看清事件背后的结构和各要素之间的互动关系,并主动地“建构”和“解构”系统构建的各种可能。

        以事件为线索进行反推,是可以找到触发事件的命令及命令的发出者的,命令执行成功后产生事件。在实践的过程中,经常被问到的问题是查询商品算不算命令?这里有一个权衡标准,当在超市购物时,我们也会查看货架上的商品,大部分查看后并没有对我和我的购物车产生任何变化,这种没有产生副作用的操作并不是命令,当用户看完一个商品,他做了放入购物车的决定,那么,这个决定会改变其购物车的状态及后续的付款金额,即:有副作用的用户决策,可以称之为命令。

        得到命令后,很容易分析出命令的发起方,有可能是一个人或是一个系统。部分模型如下:


        到目前为止我们带着要解决的问题做的问题层面的分析,从买家如何在电商平台上购买IPHONE X开始的,到不同角色关注的领域事件,命令与角色。是时候为问题设计解决方案了,解决方案是从上图中抽象出系统元素,并看清它们之间的互动关系,系统中的元素不要使用动词,要使用名词。用动词来表述,得到的往往不是系统的结构,更像是在描述一个故事。分析后的模型如下:


        在构建任何系统时都是为了解决特定的问题,如:构建电商系统销售所有数码产品。对于问题的处理最常用到的办法是分而治之,将问题域分解成多个子域,子域解决一个或多个小问题,上图中的系统关键元素就是小问题的解决方案,这些元素我们称之为聚合。分而治之后,需要粘合这些方案协作解决整个系统要解决的问题。这时应该跳出单因思考方式,从全局看问题,透过现象看本质,分析事物之间的关系。将子关键元素自下而上的抽象出对应的子域后的部分结果是:

        对于复杂的子域,有一些相似的问题与模型,为了保证模型的整洁度,让设计元素职责单一并有效的分离模型的关注点,限定解决问题的边界可以帮助我们解决这个问题。例如:对于商品目录边界内商品的关注的属性与物流边界内商品关注的属性是不一样,把它们建模成一个商品对象,会增加模型的耦合度,语义上也会存在二义性,在语义边界内建模会简化与解耦对象模型,将这种边界与语义的限定称为限界上下文。


        限定语义边界内的一组对象解决了系统中的一类问题,有了限界上下文,系统模型开始从具体演进到抽象,也方便从抽象层面确定模型之间的关系,DDD中称之上下文关系映射,从限界上下文层面将不同的子问题联系起来让它们相互协作来解决问题。下图中用U(Upstrean)与D(Downstream)来表示上下游之间的关系,要注意上下游的方向,方向代表了特定的含义,如果U/D画反,很可能会陷入思考的误区。

        上图是我们面向领域事件建模的成果,如果作为微服务系统设计过程,你已经完成了服务分析,服务设计与服务拆分,一般情况每个限界上下文会被建模成一个服务,上文中提到的关键要素被建模成聚合。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,175评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,674评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,151评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,597评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,505评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,969评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,455评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,118评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,227评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,213评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,214评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,928评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,512评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,616评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,848评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,228评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,772评论 2 339

推荐阅读更多精彩内容