产品战略专家梁宁确认出席AICon北京站,分享AI时代下的商业逻辑与产品需求 了解详情
写点什么

DDD 被高估了吗?

  • 2021-03-25
  • 本文字数:1222 字

    阅读完需:约 4 分钟

DDD被高估了吗?

本文最初发布于 INNOQ 博客,经原作者授权由 InfoQ 中文站翻译并分享。


领域驱动设计(DDD)最近越来越受欢迎,新出版的图书、会议演讲以及大量培训就是证明。


虽然很长时间以来,我一直都非常推崇这种方法,但最近,一些人对待它的方式让我恼火。


确切地讲,DDD 这种模式语言为许多知道如何做但不知道如何有效沟通协调的开发人员和设计人员提供了明确的语言。


但我生气的是,最近,似乎任何时候,当有人谈论如何设计系统或服务边界,或者只是提到非技术设计时,每个人都感觉不得不引进 DDD 专家——好像他们是唯一可以设计这些东西的超级英雄。这和其他类似的情况一样糟糕,你盲目地应用当前流行的解决方案,仅仅因为它是每个人都在谈论的事情,而不是因为它是这项工作的正确解决方案。


DDD 很棒,但它只是你应该注意的众多工具和技术之一。


在 DDD 的战略维度中,最常用的工具是“有界上下文”的概念——一个给定的模型通常可以,而且应该被细分为更小的单元,每个单元为特定的概念赋予符合它们自己上下文的特定含义。好主意!这(当然)也不是 DDD 的发明:它只是简单的模块化设计,已经被设计大型系统的人们应用了几十年。


这是否意味着有界上下文的概念有问题呢?不,事实上,该模式的目的是为已经存在并证明了其价值的东西命名。我并不是说有界上下文有什么问题,我只是想指出,有些人可能在没有使用或甚至不知道这个特定称谓的情况下做了出色的系统设计。


在战术层面,人们忽略了一个更重要的方面,特别是当他们将 DDD 作为设计入门时。DDD 强调命名的重要性,并建议你在设计中尽量使用一种通用的、普遍存在的语言。但对于系统设计领域,它也使用自己的语言——诸如有界上下文、聚合、实体、值对象等概念。虽然这些都很好,但它们只是一种可行的语言。将一个值对象称为值对象是有价值的,如果这是一个很多人都理解的术语,就会有助于交流。


但是,现有的、常见的 DDD 概念并不是你唯一应该考虑的概念——它们只是设计和架构系统时一些非常常见的特征的范例:提出并识别模式,给它们起个名字,并使用它们来给出系统结构,保证系统统一性。如果在你的架构中,有一种常见的模式,你使用一个 Filter 将请求路由到一个 Handler,或是使用一个由 Agent 处理的概念 Document,那么这类事情可能会多次发生,和服务或存储库在同一层次上,最终变成对你而言更重要的东西。这很好!


我们可以并且应该发明自己的语言,这种思想比许多天真的 DDD 从业者所认为的要重要得多。我相信 DDD 专家对此非常了解,并将任何 DDD 材料视为起点,而不是最终结果。但是,如果你所做的一切都是按照现有的 DDD 标准术语定义,并试图将任何问题都硬塞到现有的结构中,那么你的生活将非常悲惨。


将 DDD 作为工具集的一部分,但要确保你不会止步于此。有一种生活超越了 DDD。并不是每一个好的设计都需要领域驱动(尽管我认可它应该总是由领域驱动的,只是不一定是 DDD 意义上的)。即使你不是 DDD 专家,也可以设计出好的系统。


原文链接:


https://www.innoq.com/en/blog/is-domain-driven-design-overrated

2021-03-25 11:223364
用户头像

发布了 733 篇内容, 共 469.0 次阅读, 收获喜欢 1544 次。

关注

评论 3 条评论

发布
用户头像
DDD在思想上创新不多,最大的贡献是规范化命名。
最可恶的是有些人故意讲得玄幻。
门槛高的技术都是必死的。
2021-10-12 20:23
回复
用户头像
DDD 很棒,但它只是你应该注意的众多工具和技术之一。
2021-03-29 15:37
回复
用户头像
骂得好,为了用而用,为了KPI而用,为了吹牛逼而用,为了学习新知识而用,都是不负责的表现
2021-03-26 15:07
回复
没有更多了
发现更多内容

Server Queue 提高 QPS

风含叶

Python kafka 后端 队列

纯CSS“返回顶部”特效

寇云

CSS css3

团队与领导力健康检查 | 体检表

Bob Jiang

团队建设

如何设计数据中台

数据社

大数据 数据中台 数据仓库

做好领路人——写给技术新人的导师建议

南方

管理 新人

一款开源且具有交互视图界面的实时 Web 日志分析工具!

JackTian

开源 GoAccess 实时 Web 日志分析工具 交互式查看器

GitHub 上十个好用的软件

彭宏豪95

GitHub 效率 工具

这场大数据+AI Meetup,一次性安排了大数据当下热门话题

Apache Flink

大数据 flink 流计算 实时计算

原创 | 使用JUnit、AssertJ和Mockito编写单元测试和实践TDD (十一)JUnit概述

编程道与术

Java 编程 软件测试 TDD 单元测试

如何通过样本数据推断其分布

张利东

Python

写给产品经理的信(5):谈谈项目管理(青铜-王者)

punkboy

产品 极客时间,项目管理 项目管理 产品经理 项目

自定义构造python白名单__builtins__

么么哒

Python

自定义列表样式

寇云

CSS css3

最香远程开发解决方案!手把手教你配置VS Code远程开发工具,工作效率提升N倍

程序员柠檬

Linux 后台开发 vscode 后端

git | IDEA 中如何压缩提交(压缩commit后再push 图文演示)

YoungZY

开发者工具 IDEA 开发工具

python实现·十大排序算法之基数排序(Radix Sort)

南风以南

Python 排序算法 基数排序

券商也“网红”,证券行业IT服务运维发展按下“快进键”

博睿数据

运维 APM 证券 券商 行情

写代码没几天,遇到一堆报错,我该怎么办

刘早起😶

Python 程序员 程序人生

关于软件测试的三点思考

卓然

软件测试 测试 测试的价值 联现技术咖

机器学习项目是如何开发和部署的?

陆道峰

人工智能 学习

前端工程化之创建项目

春生

大前端 全栈工程师

HTML中实现合并单元格

JDoe

html

只用CSS实现响应式Full-Width img 2种方法

寇云

CSS css3

重学 Java 设计模式:实战原型模式

小傅哥

Java 设计模式 小傅哥 复杂代码优化 重构

Python deepcopy一个优化

么么哒

Python

“新基建”方兴未艾,Smartbi Mining如何为产业数字化转型赋能?

infoq小陈

偏头疼告诉我的,我想告诉每一个人

zkback

为什么第三方联调应该先行?

大伟

为什么要学习 Markdown?究竟有什么用?

JackTian

markdown markdown语法 markdown编辑器

地铁上看书的老外引发的思考

小天同学

写作 读书 个人感想 日常思考

互联网省份数据大揭秘,看看哪些地方是互联网的戈壁滩?

非著名程序员

程序员 互联网 IT

DDD被高估了吗?_架构_STEFAN TILKOV_InfoQ精选文章