《实现领域驱动设计》拆书稿 - 第1章 DDD入门

《实现领域驱动设计》拆书稿--持续更新

pic-08.jpeg

第1章:DDD入门

拆书稿

一、为什么我们需要DDD?

  • 使领域专家和开发者在一起工作,这样开发的软件能够准确地传达业务规则。
  • "准确传达业务规则"意思是说:此时的软件就像是领域专家是编码人员时所开发出来的一样。
  • 可以帮助业务人员自我提高。
  • 确保软件知识并不只是掌握在少数人手中。
  • 在领域专家、开发者和软件本身之间不存在"翻译"。
  • 设计就是代码,代码就是设计。
  • DDD提供了战略设计和战术设计两种方式。
    • 战略设计:帮助我们理解哪些投入是最重要的;

    哪些既有软件资产是可以重新拿来使用的;哪些人应该被加到团队中?
    * 战术设计:帮助我们创建DDD模型中各个部件。

二、DDD是什么?

DDD是一种软件开发方法

  • DDD将领域专家和开发人员聚集到一起,开发的软件能够反映出领域专家的思维模型。目标是:交付最具业务价值的软件。
  • DDD关注业务战略:指引我们如何实现面向服务架构(service-oriented architecture)或者业务驱动(business-driven architecture)架构。
  • 使用战术设计建模工具:这些战术设计工具使开发人员能够按照领域专家的思维模型开发软件。保证成功地交付真正的业务价值。

我们平时一些常见的设计问题

  • 贫血症

现象:
你的领域对象包含了太多和业务没有关系的属性。
你的领域对象只是将关系型数据库中的模型映射到了对象上而已。

  • 失忆症

由贫血设计导致的失忆症问:
1、业务意图不明确;
2、方法的实现本身增加了潜在的复杂性;
3、领域对象根本就不是对象,而只是一个数据持有器(data holder);
......

三、如何DDD?

1、理解两大支柱:

通用语言、限界上下文(Bounded Context)

2、如何掌握和建立通用语言?

  • 模型图:同时绘制物理模型图和概念模型图(不正式,区别于UML),并标以名字和行为;

  • 术语表:创建一个包含简单定义的术语表和词组;

  • 共创:找团队的其他成员来检查你的术语表和词组;

四、使用DDD有什么业务价值?

  • 获得了一个非常有用的领域模型
  • 业务得到了更准确的定义和理解
  • 领域专家可以为软件设计做出贡献

    减少只有少数人才了解模型的情况

  • 更好的用户体验
  • 清晰的模型边界
  • 更好的企业架构
  • 敏捷、迭代式和持续建模
  • 使用战略和战术新工具

    战术建模工具:聚合(Aggregate)、实体(Entity)、值对象(Value Object)、领域服务(Domain Service)、领域事件(Domain Event)

五、实施DDD所面临的挑战和心理准备

  • 要花费大量时间和精力来思考业务领域,研究概念和术语。
  • 持续地将领域专家引入项目
  • 改变开发中对领域的思考方式

读后思考

1、什么是架构设计?

  • 现在架构师一般工作流程是怎么样的?

    现在很多架构师和家装公司的相似性;设计了一套架构,无论预先设计如何"精确",发现需求总是在变,前面总是有坑,情况越来越糟,最后不得不重写。​

  • 软件架构设计的本质是什么?

    让系统能够更快地响应外界业务的变化,并且使得系统能够持续演进。在遇到变化时不需要从头开始,保证实现成本得到有效控制。

2、DDD能解决我们什么问题?

  • 原来的架构模式满足不了业务快速变化

    • 原来的架构都是针对技术的,DDD把业务和系统架构绑定在一起来考虑,提高针对业务变化的高响应力。

    从业务出发、面向业务变化是我们现代架构设计成功的关键。架构设计的核心实质是保证面对业务变化时我们能够有足够快的响应能力。

  • 团队中各个角色的沟通成本高居不下

    • 在团队中各个角色之间建立通用语言;

    同一个团队中(产品、开发、测试)使用同一种架构语言;
    不同团队中,可以避免组件划分过程中的边界错位。

3、结合实际项目的思考问题

  • 在目前的团队项目中如何进行DDD?
  • 可能遇到的困难和阻力是什么?
  • 在当前项目或团队中进行DDD,你期望达到的目标和效果是什么?

推荐阅读

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

推荐阅读更多精彩内容

  • 有位朋友最近在为企业做领域驱动设计(Domain Driven Design)内训时,遇到一位资深学员向他抱怨该技...
    MagicBowen阅读 18,649评论 8 66
  • 本文首发于 vivo互联网技术 微信公众号链接: https://mp.weixin.qq.com/s/gk-Hb...
    vivo互联网技术阅读 987评论 0 0
  • 小时候学过一篇课文叫《小白兔和小灰兔》,说的是小白兔和小灰兔帮助山羊爷爷收菜,山羊爷爷送给他们一人一车菜。...
    草叶上的歌_dd7d阅读 354评论 0 2
  • 最终胜利的,一定是即使不断失败,依旧一直前行的人。 看到这句话,突然感触,我们的日记群不就是一群人,互相鼓励着不断...
    婉珊1219阅读 80评论 1 1
  • 这是来福,今早出门碰到大姐牵着三只狗狗,其中这个狗狗名字就叫来福。记得当时还差点送给我。 小区角落的花。 小黑 来福
    1028nss阅读 66评论 0 1