DDD - 微服务架构模型_领域驱动设计(DDD)分层架构 vs 整洁架构(洋葱架构) vs 六边形架构(端口-适配器架构)

文章目录

  • 引言
  • 1. 概述
  • 2. 领域驱动设计(DDD)分层架构模型
    • 2.1 DDD的核心概念
    • 2.2 DDD架构分层解析
  • 3. 整洁架构:洋葱架构与依赖倒置
    • 3.1 整洁架构的核心思想
    • 3.2 整洁架构的层次结构
  • 4. 六边形架构:解耦核心业务与外部系统
    • 4.1 六边形架构的设计理念
    • 4.2 六边形架构的适用场景
  • 5. 三种架构模型的对比与适用场景
    • 5.1 架构模型的核心对比
  • 6. 微服务架构设计中的分层与解耦
    • 6.1 微服务的分层设计
    • 6.2 领域模型与应用层的分离
    • 6.3 资源解耦与适配策略
  • 7. 中台架构与微服务架构的融合
    • 7.1 中台架构的核心思想
    • 7.2 微服务与中台架构的结合
      • 项目级微服务
      • 企业级中台微服务
  • 8. 最佳实践:如何实现高内聚低耦合的微服务
    • 8.1 业务逻辑与外部依赖的解耦
    • 8.2 微服务之间的通信与集成
    • 8.3 服务的独立性与可扩展性
  • 9. 小结

在这里插入图片描述


引言

在当今的技术架构中,微服务架构已成为构建大规模分布式系统的主流方式。相较于传统的单体架构,微服务架构以其灵活、可扩展、高可用和高容错的特点,帮助企业应对快速变化的业务需求。然而,微服务架构并非万能,它对系统的设计和开发提出了新的挑战,特别是如何正确理解和运用微服务架构模型,确保系统能够高效、稳定地运行。

接下来我们将对几种常见的微服务架构模型进行详细分析,包括领域驱动设计(DDD)分层架构整洁架构六边形架构(端口-适配器架构),探讨如何利用这些架构模型设计高内聚低耦合的微服务架构。

1. 概述

微服务架构(Microservices Architecture)是一种将单一应用程序拆解为多个小型服务的架构风格。每个微服务实现一个业务功能,独立部署和独立扩展,这种方式极大地提升了系统的灵活性、可维护性和可扩展性。微服务架构的核心优势包括:

  • 松耦合:每个微服务都可以独立演化,修改一个微服务不会影响到其他服务。
  • 独立部署:每个微服务可以独立部署,减少了系统升级时的风险。
  • 技术栈多样性:不同的微服务可以采用不同的技术栈,选择最适合的工具和框架。
  • 高可扩展性:通过服务拆分,可以根据业务需要独立扩展某个服务,避免了单体应用的性能瓶颈。

然而,微服务架构也面临着挑战。特别是在系统复杂性大幅提升时,如何保证微服务之间的协调、服务的可靠性以及如何正确划分服务边界成为了微服务架构设计中的关键问题。微服务架构的成功不仅仅取决于服务的拆分,还取决于如何设计合适的架构模型和分层策略。


2. 领域驱动设计(DDD)分层架构模型

领域驱动设计(Domain-Driven Design, DDD)是一种以领域模型为核心的架构设计理念,旨在通过深入理解业务领域,实现系统设计和开发的高效协同。DDD倡导将业务领域模型作为核心,围绕领域模型进行系统的设计与实现。
在这里插入图片描述

2.1 DDD的核心概念

DDD的核心概念包括:

  • 领域(Domain):是指应用程序所要处理的实际问题空间,包含了所有与业务相关的概念和规则。
  • 限界上下文(Bounded Context):将系统划分为多个子领域,每个子领域内部的模型和规则都是独立的。
  • 领域模型(Domain Model):领域模型是领域中关键概念的抽象,用于表示业务实体及其之间的关系和行为。

2.2 DDD架构分层解析

DDD的分层架构包括:

  1. 领域层(Domain Layer):负责核心业务逻辑的实现,包括领域模型和领域服务。领域层是系统的核心,承载着系统的业务规则。
  2. 应用层(Application Layer):负责处理用户请求,调用领域层的功能,完成业务流程。应用层并不包含业务逻辑,而是通过领域层来实现业务功能。
  3. 接口层(Interface Layer):负责与外部系统(如UI、外部API等)的交互。接口层通过应用层向用户或外部系统提供服务。
  4. 基础设施层(Infrastructure Layer):提供数据存储、消息队列等底层资源的支持。基础设施层实现与外部系统的集成。

通过这种分层,DDD确保了系统的业务逻辑与外部依赖的解耦,使得业务模型能够独立演化,不受外部系统变动的影响。


3. 整洁架构:洋葱架构与依赖倒置

整洁架构(Clean Architecture)由Robert C. Martin提出,其核心思想是将系统的核心业务逻辑与外部技术细节进行隔离。整洁架构强调分层设计,并通过依赖倒置原则(Dependency Inversion Principle)来实现各层之间的解耦。

在这里插入图片描述

3.1 整洁架构的核心思想

整洁架构的核心思想是将应用划分为多个层次,每个层次负责不同的职责。其结构类似于洋葱,每一层都像洋葱的外皮一样包裹着内层,外层依赖于内层,而内层则完全不依赖于外层。

  • 核心层:包括领域模型、领域服务和应用服务,这些层次实现了核心的业务逻辑。
  • 外部层:包括用户接口、数据库、缓存、消息队列等,这些层负责与外部世界的交互。

3.2 整洁架构的层次结构

整洁架构的典型层次结构如下:

  1. 核心层(Core Layer):包含领域模型、领域服务、应用服务等,它们定义了应用的核心业务逻辑。
  2. 接口层(Interface Layer):定义了系统与外部交互的接口,如UI层、API层等。
  3. 基础设施层(Infrastructure Layer):负责数据库、文件系统、缓存等基础设施的实现。
  4. 外部适配层(External Adapter Layer):通过适配器连接不同的外部系统和服务。

整洁架构的关键是通过依赖倒置原则,使得核心业务逻辑和外部技术细节解耦,从而提高了系统的可维护性和可扩展性。

4. 六边形架构:解耦核心业务与外部系统

六边形架构(Hexagonal Architecture),也被称为端口-适配器架构(Ports and Adapters Architecture),旨在通过端口和适配器的方式解耦核心业务与外部系统。六边形架构的关键是将应用的核心业务逻辑放在“内六边形”中,外部世界通过“端口”和“适配器”与应用进行交互。

在这里插入图片描述

4.1 六边形架构的设计理念

六边形架构的核心设计理念是应用的核心业务逻辑与外部世界的交互通过端口和适配器进行隔离。这意味着,外部的API、数据库、用户接口等都与核心业务逻辑解耦,系统可以灵活适配不同的外部需求。

六边形架构将系统划分为两层:

  • 内六边形(Core Logic):包含应用的核心业务逻辑。该层不依赖

于外部系统,任何变化都不会直接影响到核心逻辑。

  • 外六边形(External Adapters):通过适配器连接外部系统和应用的核心逻辑。适配器负责转换外部请求为应用能够处理的形式。

4.2 六边形架构的适用场景

六边形架构特别适用于以下场景:

  • 复杂业务逻辑:当系统中存在复杂的业务逻辑时,六边形架构能够帮助我们将业务逻辑与外部依赖解耦,确保业务的稳定性。
  • 多样化的外部系统集成:当系统需要与多个外部系统(如数据库、第三方服务、消息队列等)集成时,六边形架构能够通过适配器将这些集成方式抽象化。

5. 三种架构模型的对比与适用场景

在这里插入图片描述

5.1 架构模型的核心对比

特性DDD分层架构整洁架构六边形架构
核心理念聚焦领域模型,分层设计核心业务逻辑独立,解耦技术细节通过端口和适配器解耦核心逻辑与外部系统
分层领域层、应用层、接口层核心层、接口层、基础设施层内六边形(核心业务)和外六边形(适配器)
外部依赖解耦限界上下文划分,避免跨界限依赖依赖倒置,核心逻辑不依赖外部通过端口与适配器解耦外部依赖
适用场景复杂领域模型、大型企业应用需要独立部署和扩展的系统需要灵活适配多种外部系统的场景

6. 微服务架构设计中的分层与解耦

6.1 微服务的分层设计

微服务架构设计中的分层结构通常包括以下几层:

  1. 表示层(API层):负责与用户或外部系统交互,暴露服务接口。
  2. 服务层(业务层):处理业务逻辑,协调不同微服务之间的交互。
  3. 领域层:负责领域模型的实现和核心业务逻辑的处理。
  4. 数据层:负责数据存储和持久化。

6.2 领域模型与应用层的分离

领域模型是系统的核心,它应与应用层分离。应用层负责协调不同微服务的调用,而领域模型则专注于业务逻辑的实现。


6.3 资源解耦与适配策略

通过引入适配器和防腐层(Anti-Corruption Layer),可以确保新系统和旧系统之间的解耦,避免旧系统的技术细节影响新系统的业务逻辑。


7. 中台架构与微服务架构的融合

中台本质上是领域的子域,它可能是核心域,也可能是通用域或支撑域。通常大家认为阿里的中台对应 DDD 的通用域,将通用的公共能力沉淀为中台,对外提供通用共享服务。


7.1 中台架构的核心思想

中台架构的核心思想是将企业的共性能力提炼成中台服务,提供给不同业务线使用。通过中台,企业能够实现资源共享、能力复用,从而提升整体运营效率。


7.2 微服务与中台架构的结合

微服务架构与中台架构相结合,可以有效解决大规模企业中各个业务单元之间的协作问题。微服务架构可以为每个业务单元提供独立的服务,中台则提供公共服务和资源管理,从而减少重复开发和维护成本。


项目级微服务

在这里插入图片描述

项目级微服务的内部遵循分层架构模型就可以了。领域模型的核心逻辑在领域层实现,服务的组合和编排在应用层实现,通过 API 网关为前台应用提供服务,实现前后端分离。但项目级的微服务可能会调用其它微服务,比如某个项目级微服务 B 调用认证微服务 A,完成登录和权限认证。

通常项目级微服务之间的集成,发生在微服务的应用层,由应用服务调用其它微服务发布在API 网关上的应用服务。图中微服务 B 中红色框内的应用服务 B,它除了可以组合和编排自己的领域服务外,还可以组合和编排外部微服务的应用服务。它只要将编排后的服务发布到 API 网关供前端调用,这样前端就可以直接访问自己的微服务了。


企业级中台微服务

企业级的业务流程往往是多个中台微服务一起协作完成的,那跨中台的微服务如何实现集成呢?企业级中台微服务的集成不能像项目级微服务一样,在某一个微服务内完成跨微服务的服务组合和编排。我们可以在中台微服务之上增加一层,你看下面这张图,增加的这一层就位于红色框内,它的主要职能就是处理跨中台微服务的服务组合和编排,以及微服务之间的协调,它还可以完成前端不同渠道应用的适配。

在这里插入图片描述

不妨借用 BFF(服务于前端的后端,Backend for Frontends)这个词,暂且称它为BFF 微服务。BFF 微服务与其它微服务存在较大的差异,就是它没有领域模型,因此这个微服务内也不会有领域层。BFF 微服务可以承担应用层和用户接口层的主要职能,完成各个中台微服务的服务组合和编排,可以适配不同前端和渠道的要求.


8. 最佳实践:如何实现高内聚低耦合的微服务

8.1 业务逻辑与外部依赖的解耦

要实现高内聚低耦合,首先要保证业务逻辑的独立性。通过DDD、整洁架构或六边形架构的应用,可以确保核心业务逻辑不受外部系统变化的影响。


8.2 微服务之间的通信与集成

微服务之间的通信方式有同步和异步两种,常见的协议有RESTful API、gRPC等。选择合适的通信方式可以减少服务之间的耦合,提高系统的性能。


8.3 服务的独立性与可扩展性

服务的独立性是微服务架构成功的关键。每个微服务应能够独立部署、独立扩展,同时保证服务之间的协作不被影响。


9. 小结

DDD 分层架构、整洁架构、六边形架构都是以领域模型为核心,实行分层架构,内部核心业务逻辑与外部应用、资源隔离并解耦 .

如何在微服务架构中实现高内聚低耦合,如何通过架构模型的合理设计提高系统的灵活性和可维护性,将是技术团队面临的主要挑战。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/10811.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LS和MMSE信道估计

1️⃣ LS(最小二乘)信道估计 OFDM系统的信道估计常在频域进行,因为OFDM本身就是基于频域的。频域模型可以表示为: Y ( f ) X ( f ) H ( f ) Z ( f ) Y(f)X(f) H(f)Z(f) Y(f)X(f)H(f)Z(f) 其中, Y ( f ) Y(f) Y(f)表…

C++ strcpy和strcat讲解

目录 一. strcpy 代码演示: 二.strcat 代码演示: 一. strcpy 使⽤字符数组可以存放字符串,但是字符数组能否直接赋值呢? ⽐如: char arr1[] "abcdef"; char arr2[20] {0}; arr2 arr1;//这样这节赋值可…

力扣257. 二叉树的所有路径(遍历思想解决)

Problem: 257. 二叉树的所有路径 文章目录 题目描述思路复杂度Code 题目描述 思路 遍历思想(利用二叉树的先序遍历) 利用先序遍历的思想,我门用一个List变量path记录当前先序遍历的节点,当遍历到根节点时,将其添加到另一个List变量res中&…

JVM运行时数据区域-附面试题

Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域。这些区域 有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而一直存在,有些区域则是 依赖用户线程的启动和结束而建立和销毁。 1. 程序计…

向上调整算法(详解)c++

算法流程: 与⽗结点的权值作⽐较,如果⽐它⼤,就与⽗亲交换; 交换完之后,重复 1 操作,直到⽐⽗亲⼩,或者换到根节点的位置 这里为什么插入85完后合法? 我们插入一个85,…

数据库备份、主从、集群等配置

数据库备份、主从、集群等配置 1 MySQL1.1 docker安装MySQL1.2 主从复制1.2.1 主节点配置1.2.2 从节点配置1.2.3 创建用于主从同步的用户1.2.4 开启主从同步1.2.4 主从同步验证 1.3 主从切换1.3.1 主节点设置只读(在192.168.1.151上操作)1.3.2 检查主从数…

【题解】AtCoder Beginner Contest ABC391 D Gravity

题目大意 原题面链接 在一个 1 0 9 W 10^9\times W 109W 的平面里有 N N N 个方块。我们用 ( x , y ) (x,y) (x,y) 表示第 x x x 列从下往上数的 y y y 个位置。第 i i i 个方块的位置是 ( x i , y i ) (x_i,y_i) (xi​,yi​)。现在执行无数次操作,每一次…

FFmpeg工具使用基础

一、FFmpeg工具介绍 FFmpeg命令行工具主要包括以下几个部分: ‌ffmpeg‌:编解码工具‌ffprobe‌:多媒体分析器‌ffplay‌:简单的音视频播放器这些工具共同构成了FFmpeg的核心功能,支持各种音视频格式的处理和转换‌ 二、在Ubuntu18.04上安装FFmpeg工具 1、sudo apt-upda…

自制虚拟机(C/C++)(二、分析引导扇区,虚拟机读二进制文件img软盘)

先修复上一次的bug&#xff0c;添加新指令&#xff0c;并增加图形界面 #include <graphics.h> #include <conio.h> #include <windows.h> #include <commdlg.h> #include <iostream> #include <fstream> #include <sstream> #inclu…

LeetCode:63. 不同路径 II

跟着carl学算法&#xff0c;本系列博客仅做个人记录&#xff0c;建议大家都去看carl本人的博客&#xff0c;写的真的很好的&#xff01; 代码随想录 LeetCode&#xff1a;63. 不同路径 II 给定一个 m x n 的整数数组 grid。一个机器人初始位于 左上角&#xff08;即 grid[0][0]…

索引的底层数据结构、B+树的结构、为什么InnoDB使用B+树而不是B树呢

索引的底层数据结构 MySQL中常用的是Hash索引和B树索引 Hash索引&#xff1a;基于哈希表实现的&#xff0c;查找速度非常快&#xff0c;但是由于哈希表的特性&#xff0c;不支持范围查找和排序&#xff0c;在MySQL中支持的哈希索引是自适应的&#xff0c;不能手动创建 B树的…

EigenLayer联合Cartesi:打造面向主流用户的DeFi、AI等新用例

EigenLayer 与 Cartesi 正在开展合作&#xff0c;致力于弥合基础设施协议与终端用户应用之间的鸿沟&#xff1b;鼓励核心开发人员构建人工智能代理、复杂 DeFi、游戏、社交网络等应用场景&#xff1b;得益于 Cartesi 基于 Linux 的协处理器&#xff0c;开发者可复用现有软件库和…

DeepSeek-R1论文研读:通过强化学习激励LLM中的推理能力

DeepSeek在朋友圈&#xff0c;媒体&#xff0c;霸屏了好长时间&#xff0c;春节期间&#xff0c;研读一下论文算是时下的回应。论文原址&#xff1a;[2501.12948] DeepSeek-R1: Incentivizing Reasoning Capability in LLMs via Reinforcement Learning 摘要&#xff1a; 我们…

MINIRAG: TOWARDS EXTREMELY SIMPLE RETRIEVAL-AUGMENTED GENERATION论文翻译

感谢阅读 注意不含评估以后的翻译原论文地址标题以及摘要介绍部分MiniRAG 框架2.1 HETEROGENEOUS GRAPH INDEXING WITH SMALL LANGUAGE MODELS2.2 LIGHTWEIGHT GRAPH-BASED KNOWLEDGE RETRIEVAL2.2.1 QUERY SEMANTIC MAPPING2.2.2 TOPOLOGY-ENHANCED GRAPH RETRIEVAL 注意不含评…

Kafka中文文档

文章来源&#xff1a;https://kafka.cadn.net.cn 什么是事件流式处理&#xff1f; 事件流是人体中枢神经系统的数字等价物。它是 为“永远在线”的世界奠定技术基础&#xff0c;在这个世界里&#xff0c;企业越来越多地使用软件定义 和 automated&#xff0c;而软件的用户更…

【学习笔记】深度学习网络-正则化方法

作者选择了由 Ian Goodfellow、Yoshua Bengio 和 Aaron Courville 三位大佬撰写的《Deep Learning》(人工智能领域的经典教程&#xff0c;深度学习领域研究生必读教材),开始深度学习领域学习&#xff0c;深入全面的理解深度学习的理论知识。 在之前的文章中介绍了深度学习中用…

Flutter常用Widget小部件

小部件Widget是一个类&#xff0c;按照继承方式&#xff0c;分为无状态的StatelessWidget和有状态的StatefulWidget。 这里先创建一个简单的无状态的Text小部件。 Text文本Widget 文件&#xff1a;lib/app/app.dart。 import package:flutter/material.dart;class App exte…

浅色可视化大屏虽然经常被诟病,也有自己的用武之地呀

一、视觉舒适性与减轻疲劳 在长时间的使用和观察中&#xff0c;浅色可视化大屏能够为用户带来更舒适的视觉体验&#xff0c;减轻视觉疲劳。与深色背景相比&#xff0c;浅色背景通常反射的光线较少&#xff0c;对眼睛的刺激相对较小。尤其是在需要长时间盯着大屏进行数据分析…

Office / WPS 公式、Mathtype 公式输入花体字、空心字

注&#xff1a;引文主要看注意事项。 1、Office / WPS 公式中字体转换 花体字 字体选择 “Eulid Math One” 空心字 字体选择 “Eulid Math Two” 使用空心字时&#xff0c;一般不用斜体&#xff0c;取消勾选 “斜体”。 2、Mathtype 公式输入花体字、空心字 2.1 直接输…

el-table组件样式如何二次修改?

文章目录 前言一、去除全选框按钮样式二、表头颜色的修改 前言 ElementUI中的组件el-table表格组件提供了丰富的样式&#xff0c;有一个全选框的el-table组件&#xff0c;提供了全选框和多选。 一、去除全选框按钮样式 原本默认是有全选框的。假如有一些开发者&#xff0c;因…