DDD开发实践流程

摘自
https://www.jianshu.com/p/8392c63b0136
https://www.jianshu.com/p/b6ec06d6b594
https://www.zhihu.com/question/25089273/answer/969378280
https://zhuanlan.zhihu.com/p/345679681

设计流程

  1. 统一语言: 通过在业务与代码中的技术之间采用共同的语言达成
  2. 战略建模: 根据业务需求划分出初步的领域和限界上下文,以及上下文之间的关系;
  3. 战术建模: 进一步分析每个上下文内部,识别出哪些是实体,哪些是值对象;对实体、值对象进行关联和聚合,划分出聚合的范畴和聚合根;
  4. 数据仓储设计: 为聚合根设计仓储,并思考实体或值对象的创建方式;
  5. 工程实施: 在工程中实践领域模型,并在实践中检验模型的合理性,倒推模型中不足的地方并重构。 在不同上下文之间适当引入防腐层

统一语言

  • 业务语言起源于公司的业务侧,业务侧拥有需要实现的概念
  • 业务语言中的术语由公司的的业务侧和技术侧通过协商来定义(意味着业务侧也不能总是选到最好的命名)
  • 目标是创造可以被业务、技术和代码自身无歧义使用的共同术语,即统一语言。
  • 要求:代码、类、方法、属性和模块的命名必须和统一语言相匹配,必要的时候需要对代码进行重构!
  • 在PRD文档、设计文档、代码以及团队日常交流中,如果有一套领域术语是统一无歧义的,会极大地提升沟通和工作效率;避免概念理解不一致,或者语言表达上的问题,导致沟通效率低,甚至发生误解
  • 明确概念、形成统一语言至关重要

战略建模 - 领域划分

领域模型: 能够精确反映领域中某一知识元素的载体

  • 无关技术,具有高度的业务抽象性;
  • 能够精确的描述领域中的知识体系;
  • 模型彼此之间独立,同时有关联
合作关系 Partnership 两个上下文紧密合作的关系,一荣俱荣,一损俱损
共享内核 Shared Kernel 两个上下文依赖部分共享的模型
客户方-供应方开发 Customer-Supplier Development 上下文之间有组织的上下游依赖
遵奉者 Conformist 下游上下文只能盲目依赖上游上下文
防腐层 Anticorruption Layer 一个上下文通过一些适配和转换与另一个上下文交互
开放主机服务 Open Host Service 定义一种协议来让其他上下文来对本上下文进行访问
发布语言 Published Language 通常与OHS一起使用,用于定义开放主机的协议
大泥球 Big Ball of Mud 混杂在一起的上下文关系,边界不清晰
另谋他路 SeparateWay 两个完全没有任何联系的上下文

战术建模—细化上下文

  • 提炼出业务中的精华,合理的抽象为实体(Entity)、值对象(ValueObject)、聚合(Aggregate)

  • 这种抽象需随着领域里的概念变化而变化

  • 结合运用这3者让项目随业务变化而进化,是DDD的核心之一

  • Entity
    可变;有唯一ID;封装实体自操作的行为

  • ValueObject
    不可变;无唯一ID;用于度量和描述事物,即属性

  • Aggregate
    实体和值对象的组合;

  • 领域服务
    领域行为
    不包含实体类中对实体自己操作的行为
    一切领域逻辑的对外暴露都需要通过领域服务来完成。

数据仓储设计

DDD数据转换流程
//数据库资源
import com.shrb.mobile.pay.card.repo.dao.CardDao;//数据库访问对象-银行卡
import com.shrb.mobile.pay.card.repo.dao.po.CardPO;//数据库持久化对象-银行卡
import com.shrb.mobile.pay.card.repo.dao.po.CardTransferPO;//数据库持久化对象-奖池

import com.shrb.mobile.pay.card.repo.cache.CardCacheAccessObj;//分布式缓存访问对象-银行卡缓存访问
import com.shrb.mobile.pay.card.repo.repository.CardRepository;//资源库访问对象-银行卡资源库

工程实施

通过模块将限界上下文进行区分
样例: com.公司名.归属团队.业务.上下文.*

对于模块内的组织结构,一般按照领域对象、领域服务、领域资源库、防腐层等组织方式进行定义,以对应DDD中各个概念

import com.shrb.mobile.pay.card.*;//支付卡上下文
import com.shrb.mobile.pay.card.domain.valobj.*;//领域对象-值对象
import com.shrb.mobile.pay.card.domain.entity.*;//领域对象-实体
import com.shrb.mobile.pay.card.domain.aggregate.*;//领域对象-聚合根
import com.shrb.mobile.pay.card.service.*;//领域服务
import com.shrb.mobile.pay.card.repo.*;//领域资源库(仓库),封装了获取对象的逻辑,领域对象无须和底层数据库交互,它只需要从仓库中获取对象即可
import com.shrb.mobile.pay.card.acl.*;//领域防腐层

import com.shrb.mobile.pay.riskcontrol.*;//支付交易风控上下文
...
import com.shrb.mobile.pay.route.*;//支付路由上下文
...
import com.shrb.mobile.pay.thirdparty.*;//外部三方支付上下文
...

工厂(Factories)
用来创建复杂的实体或聚合
以下场景不需要工厂:
a)构造器很简单
b)构造对象时不依赖于其他对象的创建
c)用策略模式就可以解决的

防腐层
以下场景考虑引入防腐层

  • 需要将外部上下文中的模型翻译成本上下文理解的模型。
  • 不同上下文之间的团队协作关系,如果是供奉者关系,建议引入防腐层,避免外部上下文变化对本上下文的侵蚀。
  • 该访问本上下文使用广泛,为了避免改动影响范围过大。

防腐层就是一个不同限界上下文之间的Adapter,主要做的工作就是数据转换

将其他领域的实体转换成当前限界上下文可以处理的实体,在不同上下文中做了一层隔离,这样当其他限界上下文业务实体有改动的时候,可以将对本限界上下文的影响降到最小。

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

推荐阅读更多精彩内容