【热点】领域驱动设计的下层设计

简介: 关注公众号“达摩院首座”,了解开发者最真实生活

不同于DDD的战略规划,战术规划更偏重于实施的细节,更聚焦于在单个有界上下文中的组件排布并且有各自通用的组件开发标准,在产品开发过程中可能会变更战术规划。

在上节课中,我们讲到了DDD的顶层设计包括了领域规划,各子域规划和域内的通用语言。作为单个子域的设计,有效的域模型是下层规划的关键。

1.png

因此下层规划也通常被称为模型驱动设计,与之密切相关的包括服务设计、实体设计、分层架构设计以及值对象。

2.png

一个子域就是一个服务,当然子域还可以包含多个微服务,这些微服务的设计是为了更好的理解子域内的业务逻辑。微服务的设计通常以分层的方式实现。比如金拱门的门店服务可以划分为接待层(负责记录客户订单和收银)、调度层(负责订单调度和队列管理)、业务层(负责准备食物)、持久化层(原始食材)。基于这样的分层式结构订单处理得会更加高效,每一层的权责明确,复用度高且可以独立扩展。
3.jpg
值对象是领域中不需要唯一标识的领域概念,通常在业务中,我们不需要区分对象是哪一个,而只关心对象是什么,这样的对象我们认为是值对象。如果两个对象所有状态都一样,我们就认为是同一个值对象,比如地址信息、订单状态信息等。值对象是只读的,具有不变性不能直接修改,但可以被替换。如果我们要修改一个客户的街道信息,应该是Customer.Address address=new Address(); address.Street=; 而不应该是Customer.Address.Street=;

下层设计中的实体对于熟悉数据库设计的开发人员来说一定不陌生,实体可以用唯一ID表示的,由一个或多个值对象组成,通常表现为数据库中的一行并由前端应用的业务逻辑进行增删改查。

实体通常是以集合(Aggregate)的表现形式呈现出来的,从业务角度讲我们不大会关注某一笔具体交易或某一个客户的消费行为,而会从全局角度剖析某类人群或某个区域的市场反应。因此对于客户或订单的关联系统,任何客户或订单的信息更新,都需要立即同步到其关联系统,才能使集合快速更新。
4.png
最后,工厂和仓库是用来生产集合的工具,工厂可以不断将实体制造成新的集合(通常由函数代码实现);仓库用来存放各种集合(通常由数据库物化视图实现)。仓库不单单是一个数据访问对象,而是存放部分实体数据并可以对其进行更新。

5.png

既然都聊得这么深入了,下集开始,小编会介绍DDD的具体实现。内容上也会加入一些代码段的部分以让开发人员也可以了解领域驱动设计的思想,下期见啦~

相关文章
|
设计模式 JSON 架构师
你真的需要防腐层吗?DDD 系统间的7种关系梳理与实践
当提到系统间交互的时候,人们都会想到大名鼎鼎的防腐层,用来防止其他系统的模型变更对本系统造成影响。但是在实践这个模式的过程中,我们常常会遇到问题。此时我们也应该考虑下其他的系统交互方式。
26738 12
你真的需要防腐层吗?DDD 系统间的7种关系梳理与实践
|
2月前
|
存储 缓存 前端开发
构建前端防腐策略问题之防腐层帮助前端实现稳定性兜底难的问题如何解决
构建前端防腐策略问题之防腐层帮助前端实现稳定性兜底难的问题如何解决
|
3月前
业务架构问题之什么是自上而下和自下而上的设计方法
业务架构问题之什么是自上而下和自下而上的设计方法
111 18
|
3月前
软件复用问题之复用决策中,业务架构和技术之间有何关系
软件复用问题之复用决策中,业务架构和技术之间有何关系
|
3月前
|
开发者
领域驱动设计问题之为什么防腐层允许随时挖掘隐式概念
领域驱动设计问题之为什么防腐层允许随时挖掘隐式概念
|
3月前
业务系统架构实践问题之平衡SPI的语义精确性和实现的复杂性问题如何解决
业务系统架构实践问题之平衡SPI的语义精确性和实现的复杂性问题如何解决
|
3月前
|
存储 搜索推荐 API
业务系统架构实践问题之分层架构中的四层定位是什么
业务系统架构实践问题之分层架构中的四层定位是什么
|
3月前
业务系统架构实践问题之什么是业务层臃肿,能力层单薄如何解决
业务系统架构实践问题之什么是业务层臃肿,能力层单薄如何解决
|
12月前
|
设计模式 网络协议 Java
《移动互联网技术》 第十章 系统与通信: 掌握Android系统的分层架构设计思想和基于组件的设计模式
《移动互联网技术》 第十章 系统与通信: 掌握Android系统的分层架构设计思想和基于组件的设计模式
103 0
|
存储 消息中间件 缓存
实现多级缓存架构设计方案
TMC,即“透明多级缓存(Transparent Multilevel Cache)”,是有赞 PaaS 团队给公司内应用提供的整体缓存解决方案。 TMC 在通用“分布式缓存解决方案(如 CodisProx
实现多级缓存架构设计方案