正文开始之前,想先问你一个问题:说到 DDD(Domain Driven Design),你的第一反应是什么,想一想?
对于这个玩意,最早接触的时候觉得这个东西太高深了,有点把握不住,云里雾里的感觉。但是随着自己一点点深入的了解,其实发现这玩意其实“不过如此”,DDD 并不是一种新技术名称,应用框架之类的东西,而是一种比较好的业务重构的思想、一种独具特色的架构风格。事实上,作为软件开发方法学层面的 DDD,并不仅仅局限于像微服务这样特定的架构风格,而是在企业数字化转型中有着广泛的应用。因此,目前各大公司也纷纷在核心业务中落地 DDD,例如京东物流、阿里零售、美团等等。虽然 DDD 在这几年越来越流行,但不少人对 DDD 的基本概念、核心技能还不能充分地掌握,从而影响了 DDD 的学习和落地。至于到底要不要学 DDD,我们可以问问 Chatgpt:
DDD 到底是什么?
DDD,也就是“领域驱动设计”,是一种开发复杂软件的系统化的方法学和思想它继承了面向对象和敏捷方法的精华,并提炼了一套更容易掌握的原则、模式和实践,特别适合复杂的企业应用的开发。 一方面,数字化时代为软件开发带来了新的挑战。如何实现业技融合,如何应对复杂多变的需求,如何防止架构和代码的腐化等问题,需要新的解决办法。而 DDD 正是顺应了时代的要求,日益普及起来。 另一方面,优秀的工程师,尤其是想挑战架构师角色的同学,DDD 更是必修内容。这点在很多大厂招聘要求上也能看到,毕竟大厂软件更复杂,需求变化快,而且代码工程的规模也更大,这些都需要你深入了解和实践过 DDD。 那么,怎样跨越学习 DDD 的门槛,扫清落地 DDD 的障碍呢?虽说难点不少,但是你也大可不必担心。DDD 的学习还是有方法,有诀窍的。我们需要的是一套既有理论高度,又顾及实践细节;既能深入复杂概念,又符合认知规律的学习方法。 这里给大家分享一张钟敬梳理的「DDD 学习」知识地图,内容出自于《手把手教你落地 DDD》专栏,你可以跟着这个“套路“建模型、写代码,拾级而上,循序渐进地掌握 DDD: 本课程适合对 DDD 感兴趣的初级和中级开发人员,尤其是已经学习过 DDD 的一些基础知识,但仍然觉得有些概念不太清楚,或落地有困难的伙伴。 对产品经理、领域专家也有参考价值:可以忽略课程中的技术部分,只关注领域建模层面从而掌握,并与开发人员有效沟通的技能。
再跟大家聊聊「钟敬」
钟敬目前在 Thoughtworks 公司担任首席咨询师,也是数字化转型与运营团队的 DDD 交付负责人。
作为一名在 IT 界奋斗了二十多年的老兵,他先后在中国人寿、友邦资讯、Thoughtworks 等公司任职。目前的主要工作是为企业提供软件开发方法学、架构设计、工程效能提升等方面的帮助。业余时间还翻译了 Martin Fowler 的《分析模式:可复用的对象模型》,审校了《领域特定语言》、《DDD 十五年》等书籍。 这些年,随着数字化转型的浪潮,他带领团队为很多家大中型企业,在几十个项目里引入了 DDD,解决了很多实际的痛点和问题。在这个过程中,他总结了一套行之有效的学习和落地 DDD 的方法,并且尝试着把这些知识经验传授给更多的人。 他希望,通过这些努力,可以让更多人了解和使用DDD,为他们自己的职业生涯开辟更多的可能性。 所以,他跟极客时间合作推出了《手把手教你落地 DDD》专栏。可以说,他对 DDD 的建模、架构和落地的各方面知识和技能都了如指掌,这种资历的大佬能出来开课,把自己独特的方法和经验共享出来,真的很难得。
如果你也想建立 DDD 完整的知识图景,掌握 DDD 最核心的技能,不要错过这个专栏。
DDD 到底是什么? 为了帮你和你的团队顺利掌握和落地 DDD解决领域建模不好掌握、领域模型难以实现、概念混乱等痛点问题,本课程将以一个企业管理系统案例为导向,模拟敏捷开发过程,带你体验系统开发的三个迭代。每个迭代的需求规模逐渐扩大,复杂性逐渐增加,相应也会让你不断学习新的 DDD 模式和实践,同时深化已学过的 DDD 技能。 迭代一:打通 DDD 的最小闭环 主要会带你夯实基础实现一个“麻雀虽小、五脏俱全”的项目打通从需求分析,到领域建模,再到架构设计,最后到数据库和代码实现的完整闭环。学完这个迭代,你就有能力处理一些不太复杂的项目了。 迭代二:聚合、值对象和泛化 深入讲解 DDD 里几个争议较大,不太好掌握的内容,包括聚合、值对象等。同时,进一步带你提升领域建模能力,深化对分层架构和代码封装的理解。最后,还会学习重要的建模技巧 -- 泛化,这是领域建模由初级走向中、高级的关键技能。学完这个部分,相信你就会有渐入佳境的感觉了。 迭代三:进阶建模、架构和落地技能 重点讲解限界上下文、事件驱动和 CQRS 等模式,带你深入讨论怎样为更加灵活多变的业务建模,帮你深化对泛化的理解。还会讲到实践落地的关键要点,比如 DDD 切入点的选择,遗留系统的改造等等。学完这个部分,你将掌握更高阶的 DDD 技能,了解如何应对更大范围的项目。 课程基本上都基于“问题 - 方案”的模式。即首先由需求引发要解决的问题,然后找到解决问题的知识点,并进行讲解。每个知识点都有具体的建模或编码实现来说明,避免空谈理论。在最后一个迭代,他还会专门讲讲如何解决落地时常见的具体疑难问题。 说了这么多,我们通过目录来看看具体内容吧: 看过课程的同学,都反馈内容非常实战,即学即用: