写点什么

别把领域驱动开发给用错了

  • 2015-04-28
  • 本文字数:727 字

    阅读完需:约 2 分钟

通常,有很多的应用声称是用领域驱动开发(DDD)构建出来的,并且有一个领域模型,但是这个模型实际上却仅仅包含业务实体,甚至于分离数据和逻辑的数据传输对象和服务都混合在了一起,其中也分不清业务和基础设施逻辑, Gabriel Schenker 分享了从事咨询和软件架构以来的个人经验。在具有消息处理的应用中,很少用业务领域中名称来命名消息,反而采用了以_update_ 或_modify_ 结尾的这种统称。

Schenker 目前是一位首席软件架构师,他说这一点儿都不夸张,他本人就常常发现早期的新应用就是这么构建出来的。Schenker 认为,这一现象的主要原因就是由于缺乏知识。

Schenker 强调说,如果采用 DDD 开展工作可以参考 Eric Evan 的 DDD 专著,但其中的所有模式的重要程度并不是安全相同的,特别是要注意这本书中后面部分的 DDD 基础,有些已经得到了 Evans 的充分肯定。与这些策略模式形成鲜明的对比的是,上半部分中的战术模式重点关注于实现的细节。

Schenker 建议说,当使用 DDD 开始一个新项目时,首先应和领域专家对业务领域达成一致的理解,把讨论中的术语抽取出来,大家共同商定创建一个通用的词汇表,在 DDD 术语中这叫做统一语言。让领域专家识别彼此间分离的区域,把复杂的领域予以分解,从而创建子领域或有边界的上下文,嘿嘿,这又是另一个DDD 术语。

Schenker 还告诫说,不要以数据模型开始创建一个以数据为中心的世界。他坚信,孤立的数据什么都不是,数据若想有意义就离不开逻辑,而且还要注意上下文的变化,所以,上下文和逻辑应该是 DDD 的主要关注点。专注于数据还有另一个风险,数据库最终会用于集成,实际上这从另一方面增加了上下文间的依赖。Stefan Tilkov 也于近期建议避免采用通用的数据模型。

查看英文原文: Domain-Driven Design the Wrong Way

2015-04-28 07:142831

评论

发布
暂无评论
发现更多内容

全面隔绝虚拟货币暴涨暴跌风险

CECBC

亚马逊云科技宣布在上海设立生命健康行业数字化赋能中心

亚马逊云科技 (Amazon Web Services)

为什么“放弃”?

Nydia

学习

写给大神

小梨蕊

情人节 520单身福利 520 单身福利

Dubbo 延迟与粘滞连接

青年IT男

dubbo

区块链技术在数字农业领域的应用挑战

CECBC

ArrayList vs LinkedList

ltc

ArrayList linkedlist

架构学习笔记:复杂度来源

风翱

5月日更 架构复杂度

一款开源小工具,提升K8S资源管理幸福感!

Rancher

夺魁!亚马逊云科技荣膺中国数据管理解决方案领导者!

亚马逊云科技 (Amazon Web Services)

线程与线程池的那些事之线程篇

秦怀杂货店

Java 线程 多线程 进程 并发

造车潮

ES_her0

5月日更

5分钟速读之Rust权威指南(六)

wzx

rust

【偶尔一道ctf】xctf adword mobile easy-apk

Thrash

IPFS与 Filecoin的区别是什么?

meio

IPFS Filecoin

博睿数据多点开花,数据链DNA加速走进金融、医疗、政企行业

博睿数据

数据链DNA

【epoll】epoll多路复用和Reactor设计思想

Linux服务器开发

后端 网络编程 C/C++ epoll Linux服务器开发

产品思维

lenka

5月日更

【签约计划】试用期规则

InfoQ写作社区官方

签约计划 热门活动

从外包跳槽到大厂,我用了55天成功逆袭。

Java 程序员 架构 面试

数据挖掘从入门到放弃(七):TensorFlow和keras实现线性回归LinearRegression

数据社

机器学习 5月日更

520,珍惜眼前人

数据社

520 520单身福利 520 单身福利

数据预处理&特征工程

Qien Z.

Python 5月日更

SWOT分析模型

石云升

创业 战略 职场经验 5月日更

破茧成蝶,如何用数据之力重塑您的业务?| 云途专栏

亚马逊云科技 (Amazon Web Services)

父母为什么催婚,而你又在逃避什么

小天同学

婚姻 爱情 5月日更

NetCore配置文件使用全过程

happlyfox

520单身福利

医疗数字化:区块链或成最强辅助

CECBC

医疗

发布两小时,Github访问量破百万,阿里内部首次公布的 Java10W 字面经有多强?

Java 程序员 架构 面试

API网关才是大势所趋?SpringCloud Gateway保姆级入门教程

Zhendong

Java spring API 网关

Flink的广播变量

大数据技术指南

大数据 flink 5月日更

别把领域驱动开发给用错了_架构_Jan Stenberg_InfoQ精选文章