DDD实战-笔记

本文探讨了DDD(领域驱动设计)在微服务和中台架构中的应用。DDD强调领域模型与微服务的一体性,通过领域、子域的划分降低复杂度,限界上下文界定业务边界。文章还介绍了实体、值对象、聚合和聚合根的概念,以及领域事件在解耦微服务中的作用。此外,讨论了DDD的分层架构,强调领域层的核心地位和应用层的协调角色,以及如何根据业务需求和变化频率进行微服务的拆分与设计。
摘要由CSDN通过智能技术生成

todo

0 开篇

中台本质是业务模型,微服务是业务模型的系统落地,DDD 是一种设计思想,它可以同时指导中台业务建模和微服务设计,它们之间就是这样的一个铁三角关系。DDD 强调领域模型和微服务设计的一体性,先有领域模型然后才有微服务,而不是脱离领域模型来谈微服务设计。

1 微服务 DDD

2 领域、子域、核心域、通用域和支撑域

DDD 的领域就是这个边界内要解 决的业务问题域。
我们把划分出来的多个子领域称为子域,每个子域对应一个更小的问题域或更小的业务范围。

领域的核心思想就是将问题域逐级细分,来降低业务理解和系统实现的复杂度。通过领域细
分,逐步缩小微服务需要解决的问题域,构建合适的领域模型,而领域模型映射成系统就是
微服务了。
核心域、支撑域和通用域的主要目标是:通过领域划分,区分不同子域在公司内的不同功能
属性和重要性,从而公司可对不同子域采取不同的资源投入和建设策略,其关注度也会不一
样。

3 界定上下文

在事件风暴过程中,通过团队交流达成共识的,能够简单、清晰、准确描述业务涵义和规则的语言就是通用语言
DDD 在战略设计上提出了“限界上下文”这个 概念,用来确定语义所在的领域边界。

通用语言:团队内部能够清晰、准确的描述业务模型的语言就是通用语言。 限界上下文:为通用语言划定边界,并提供语义上下文。领域内所有界限上下文的模型构 成了整个领域模型。 理论上,某些条件下,限界上下文的划分也最终确定了微服务的边界。

4 实体和值对象

实体有唯一ID,实体是通过ID来区分不同实体的,值对象是通过属性来区分不同值对象的,即时实体的属性都发生了改变,只要它的ID还是原来的ID,实体还是那个实体。值对象只要改变了属性值,就已经不是原来的值对象了。

在领域建模时,我们可以将部分对象设计为值对象,保留对象的业务涵义,同时又减少了实体的数量;在数据建模时,我们可以将值对象嵌入实体,减少实体表的数量,简化数据库设计。

5 聚合和聚合根

领域模型内的实体和值对象就好比个体,而能让实体和值对象协同工作的组织就是聚合,它用来确保这些领域对象在实现共同的业务逻辑时,能保证数据的一致性。

你可以这么理解,聚合就是由业务和逻辑紧密关联的实体和值对象组合而成的,聚合是数据修改和

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值