1. DDD总体结构分为四层:
- Infrastructure(基础实施层)
- Domain(领域层)
- Application(应用层)
- Interfaces(表示层,也叫用户界面层或是接口层),各个层面的作用下面介绍。
2. DDD: application 应用层
- 相对于领域层,应用层是很薄的一层,应用层定义了软件要完成的任务,要尽量简单.
- 它不包含任务业务规则或知识, 为下一层的领域对象协助任务、委托工作。
- 它没有反映业务情况的状态,但它可以具有反映用户或程序的某个任务的进展状态。
- 对外为展现层提供各种应用功能(service)。
- 对内调用领域层(领域对象或领域服务)完成各种业务逻辑任务(task)。
- 这一层也很适合写一些任务处理,日志监控
3. DDD: domain 领域层
领域层主要负责表达业务概念,业务状态信息和业务规则。
Domain层是整个系统的核心层,几乎全部的业务逻辑会在该层实现。
领域模型层主要包含以下的内容:
- 实体(Entities):具有唯一标识的对象
- 值对象(Value Objects): 无需唯一标识的对象
- 领域服务(Domain Services): 一些行为无法归类到实体对象或值对象上,本质是一些操作,而非事物
- 聚合/聚合根(Aggregates,Aggregate Roots): 聚合是指一组具有内聚关系的相关对象的集合,每个聚合都有一个root和boundary
- 工厂(Factories): 创建复杂对象,隐藏创建细节
- 仓储(Repository): 提供查找和持久化对象的方法
4. DDD: infrastructure 基础实施层
最底层(但与所有层进行交互)
向其他层提供 通用的 技术能力(比如工具类,第三方库类支持,常用基本配置,数据访问底层实现)
基础实施层主要包含以下的内容:
- 为应用层 传递消息(比如通知)
- 为领域层 提供持久化机制(最底层的实现)
- 为用户界面层 提供组件配置
- 基础设施层还能够通过架构框架来支持四个层次间的交互模式。
5. DDD: interfaces 用户界面层(或表示层)
最顶层
请求应用层以获取用户所需要展现的数据(比如获取首页的商品数据)
发送命令给应用层要求其执行某个用户命令(实现某个业务逻辑,比如用户要进行转账)
用户界面层应该包含以下的内容:
- 数据传输对象(Data Transfer Object): DTO也常被称作值对象,VO,实质上与领域层的VO并不相同
- DTO是数据传输的载体,内部不应该存在任何业务逻辑,通过DTO把内部的领域对象与外界隔离。
- 装配(Assembler): 实现DTO与领域对象之间的相互转换,数据交换,因此Assembler几乎总是同DTO一起出现。
- 表面,门面(Facade): Façade的用意在于为远程客户端提供粗粒度的调用接口
- 它的主要工作就是将一个用户请求委派给一个或多个Service进行处理,也就是我们常说的Controller。
文末
欢迎关注个人微信公众号:Coder编程
欢迎关注Coder编程公众号,主要分享数据结构与算法、Java相关知识体系、框架知识及原理、Spring全家桶、微服务项目实战、DevOps实践之路、每日一篇互联网大厂面试或笔试题以及PMP项目管理知识等。更多精彩内容正在路上~
也分享一些杂文~
文章收录至
Github: https://github.com/CoderMerlin/coder-programming
Gitee: https://gitee.com/573059382/coder-programming
欢迎关注并star~
dd