DDD 架构之领域驱动设计【通俗易懂】

news/2025/2/28 14:28:21/

文章目录

    • 1. 前言
    • 2. MVC 对比 DDD
    • 3. DDD 分层架构
    • 4. 完整业务流程

1. 前言

官方回答:DDD是一种应对复杂业务系统的设计方法,通过将软件设计与业务领域紧密结合,帮助开发人员构建清晰、可维护的领域模型。在复杂的业务系统中,它能显著提升软件设计的质量和可维护性。

说人话:传统的 MVC 三层架构业务混杂,耦合度太高,,N 年后…,这谁写的?绝对不是我,前人挖坑后人填坑,根本无从下手!

于是出现了 DDD 四层架构,简而言之,更抽象啦!

遵循三大原则:单一职责原则、开放封闭原则和依赖倒转原则。一个类只负责一项功能,对外开放扩展,对内不允许修改,并且要依赖接口开发,而非具体的实现类。

核心概念:
领域(Domain):软件要解决的业务问题。
限界上下文(Bounded Context):业务中的一个独立模块,比如“订单管理”或“用户管理”。
实体(Entity):有唯一标识的对象,比如“用户”。
值对象(Value Object):没有唯一标识的对象,比如“地址”。
聚合(Aggregate):一组相关对象的集合,比如“订单”和“订单项”。
领域服务(Domain Service):处理跨多个对象的业务逻辑。
仓储(Repository):用来存取聚合的接口。

DDD 特点:
① 业务优先技术,以领域划分为设计基础;
② DDD 以通用语言为建设核心,每个领域内有相同的包结构;
③ 以一系列抽象概念为开发模式;
④ 以四层架构为基本思想;
⑤ 有助于解决系统老化的问题。

2. MVC 对比 DDD

① 传统 MVC 是三层架构:控制层、业务层、基础层。技术优先,所有业务都混在一起:

在这里插入图片描述

MVC 架构存在的问题:
① 可维护性差,大量的第三方模块影响核心代码的稳定性;
② 可扩展性差,业务逻辑与数据存储相互依赖,无法复用;
③ 可测试性差,庞大事务脚本与基础设施强耦合,无法进行单元测试。

如何构建高质量应用?高内聚,低耦合!

② DDD 是四层架构:用户接口层、应用层、领域层、基础层。业务优先,以业务领域来划分模块:

在这里插入图片描述

3. DDD 分层架构

用户接口层:负责展示和交互,通常包括Web界面、API接口等。
应用层:协调领域层和外部系统,应用层不包含业务逻辑,主要调用领域服务。
领域层:核心业务逻辑,包括实体、值对象、聚合、领域服务等。
基础设施层:提供技术实现,如数据库访问、消息队列、外部API调用等。

核心的业务逻辑全部放在领域层,其余层都可以看作是转发站!

在这里插入图片描述

目录结构如下:

在这里插入图片描述

4. 完整业务流程

第一步,前端发起 HTTP 请求 ☞

第二步,请求进入用户接口层的 OrderController 中 ☞

第三步,OrderController 调用应用层的 OrderAppService ☞

第四步,OrderAppService 又调用了领域层的 OrderService ☞

第五步,OrderService 调用了仓储接口 OrderRepository ☞

第六步,由基础层的 OrderRepositoryImpl 处理具体的数据库关系。

如果业务简单,OrderAppService 可直接调用 OrderRepository!


http://www.ppmy.cn/news/1575523.html

相关文章

【DeepSeek】本地部署,保姆级教程

deepseek网站链接传送门:DeepSeek 在这里主要介绍DeepSeek的两种部署方法,一种是调用API,一种是本地部署。 一、API调用 1.进入网址Cherry Studio - 全能的AI助手选择立即下载 2.安装时位置建议放在其他盘,不要放c盘 3.进入软件后…

【Python pro】函数

1、函数的定义及调用 1.1 为什么需要函数 提高代码复用性——封装将复杂问题分而治之——模块化利于代码的维护和管理 1.1.1 顺序式 n 5 res 1 for i in range(1, n1):res * i print(res) # 输出:1201.1.2 抽象成函数 def factorial(n):res 1for i in range(1…

【Golang】go语言异常处理快速学习

Go 语言的异常处理与很多传统的编程语言不同,它没有 try/catch 这样的异常捕获机制,而是通过 错误类型(error)来进行错误处理。Go 语言鼓励显式地处理错误,保持代码的简单性和可维护性。在 Go 中,错误处理不…

求最小值(数组)

题目描述 给出 n 和 n 个整数 ai​,求这 n 个整数中最小值是什么。 输入格式 第一行输入一个正整数 n,表示数字个数。 第二行输入 n 个非负整数,表示 a1​,a2​…an​,以空格隔开。 输出格式 输出一个非负整数,表…

es部署报错找不到tools.jar

网上看了很多解决方法都不行,换版本,甚至用es内置的jdk都没解决问题。 原因:系统在运行时会去环境变量里找JAVA_HOME,来找到JDK运行JVM,而JVM在运行时会根据classpath的设置来加载类和资源。 此时如果你的classpath里…

在Spark中如何配置Executor内存以优化性能

在Spark中,配置Executor内存以优化性能是一个关键步骤。以下是一些具体的配置方法和建议: 一、Executor内存配置参数 在Spark中,Executor的内存配置主要通过以下几个参数进行: --executor-memory 或 spark.executor.memory&…

【MySQL】索引(上)

欢迎拜访:雾里看山-CSDN博客 本篇主题:【MySQL】索引(上) 发布时间:2025.2.26 隶属专栏:MySQL 目录 初始索引基本介绍常见索引分类案例使用 认识磁盘MySQL 与 存储关于磁盘关于扇区定位扇区结论磁盘随机访问(Random Access)与连续…

Web开发:ORM框架之使用Freesql的导航属性

一、什么时候用导航属性 看数据库表的对应关系,一对多的时候用比较好,不用多写一个联表实体,而且查询高效 二、为实体配置导航属性 1.给关系是一的父表实体加上: [FreeSql.DataAnnotations.Navigate(nameof(子表.子表关联字段))]…