实现领域驱动设计 - 使用ABP框架 - 什么是领域驱动设计?
前言:
最近看到ABP官网的一本电子书,感觉写的很好,翻译出来,一起学习下
(Implementing Domain Driven Design) https://abp.io/books
DDD简介
领域驱动设计(DDD)是一种通过将实现连接到演进的模型来实现复杂需求的软件开发方法
相对于简单的CRUD应用,DDD更适合于复杂的领域和大规模的应用。它关注核心域逻辑,而不是基础结构细节。
它有助于构建灵活、模块化和可维护的代码库。
DDD的实现高度依赖于面向对象编程(Object Oriented Programming, OOP)和SOLID原则。实际上,它实现并扩展了这些原则。因此,在真正实现DDD时,对OOP和SOLID的良好理解会对您有很大帮助
DDD分层和整洁架构
基于领域驱动的解决方案有四个基本层
业务逻辑分为两个层,领域层和应用层,而它们包含不同种类的业务逻辑
- 领域层: 实现领域/系统的核心、用例独立的业务逻辑
- 应用层: 基于领域实现应用的用例。用例可以被认为是用户界面(UI)上的用户交互。
- 表示层: 包含应用程序的UI元素(页面、组件)
- 基础设施层: 通过实现对第三方库和系统的抽象和集成来支持其他层
核心构建块
DDD主要关注领域和应用层,而忽略了表示和基础结构。它们被视为细节,业务层不应该依赖于它们
这并不意味着表示层和基础结构层不重要。它们非常重要。UI框架和数据库提供程序有它们自己的规则和最佳实践,您需要了解并应用它们。然而,这些都不在DDD的主题之内
领域层构建块
- 实体: 实体是一个具有自己属性(状态、数据)和方法的对象,这些属性实现了在这些属性上执行的业务逻辑。实体由其唯一标识符(Id)表示。两个id不同的实体对象视为不同的实体
- 值对象: 值对象是另一种类型的域对象,通过其属性而不是唯一的Id来标识。这意味着具有相同属性的两个值对象被认为是同一个对象。值对象通常被实现为不可变的,并且通常比实体要简单得多。
- 聚合和聚合根: 聚合是由聚合根对象绑定在一起的对象集群(实体和值对象)。聚合根是具有一些附加职责的实体的特定类型
- 存储库(接口): 存储库是一个类似集合的接口,域层和应用层使用它来访问数据持久性系统(数据库)。它对业务代码隐藏了DBMS的复杂性。域层包含存储库的接口
- 领域服务: 领域服务是一种无状态服务,它实现领域的核心业务规则。实现依赖于多个聚合(实体)类型或一些外部服务的域逻辑是有用的。
- 规范: 规范用于为实体和其他业务对象定义命名的、可重用的和可组合的过滤器
- 领域事件: 领域事件是在发生特定于域的事件时,以松散耦合的方式通知其他服务的一种方式
应用层构建块
- 应用程序服务: 应用程序服务是一种无状态服务,它实现应用程序的用例。应用程序服务通常获取和返回dto。它由表示层使用。它使用并协调领域对象来实现用例。用例通常被认为是一个工作单元
- 数据传输对象(DTO): DTO是一个简单的对象,没有任何业务逻辑,用于在应用程序层和表示层之间传输数据。
- 工作单元(UOW): 工作单元是作为事务单元执行的原子工作。UOW中的所有操作都应该在成功时提交,失败时回滚