六边形架构的调用流程 - 第三章 - DDD领域模型

1、六边形架构的调用流程

六边形架构的运作体现为两条清晰的调用路径:一条由外部输入驱动业务逻辑,另一条由业务逻辑驱动外部资源。理解这两条流程是掌握六边形架构实践的关键

如下:

1.1、驱动端调用流程

驱动端流程描述了外部用户或系统如何发起请求并最终被领域核心处理的过程。

其典型流程如下:

  1. 请求接收:外部请求(如HTTP请求、CLI命令、消息队列消息)首先到达对应的输入适配器。
  2. 协议转换:输入适配器负责解析请求,提取参数,并将其转换为对领域核心输入端口的普通方法调用。在此过程中,适配器完成从技术特定协议(如HTTP JSON)到领域模型(如Java对象)的转换。
  3. 业务逻辑执行:输入端口接口的具体实现(通常称为应用服务)接收到调用。该实现位于领域核心内,它协调多个领域对象(实体、值对象、领域服务),执行业务规则和逻辑。
  4. 返回响应:业务逻辑执行完毕后,结果沿原路返回。应用服务返回结果给适配器,适配器可能需将领域对象再次转换为技术特定的DTO,然后通过特定协议(如HTTP Response)返回给外部调用方。

1.2 被驱动端调用流程

被驱动端流程发生在业务逻辑执行过程中,当需要访问外部资源(如数据库、外部API)时:

  1. 接口调用:领域核心内的业务逻辑代码依赖于输出端口(接口),当需要获取或保存数据时,它直接调用输出端口接口的方法。
  2. 依赖注入:通过依赖注入框架(如Spring),在运行时实际注入的是具体的输出适配器。
  3. 技术操作执行:输出适配器实现端口接口,它负责将领域模型的指令转换为具体的技术操作,例如执行SQL语句、调用远程HTTP接口、向消息队列发送消息等。
  4. 结果转换:输出适配器从外部资源获取到数据后,将其转换回领域模型对象,并返回给领域核心。这样,领域核心始终操作的是纯粹的领域模型,而不感知数据来自何种技术实现

调用流程如下图所示:

相关推荐
JouYY8 小时前
聊一下知识答疑Agent的“层次聚类”流程
架构·llm·agent
Kel8 小时前
MCP 传输链路全链路拆解:从字节流到协议栈的四层架构之旅
人工智能·设计模式·架构
renhongxia19 小时前
原生多模态对应用架构的重塑
人工智能·深度学习·机器学习·自然语言处理·架构·机器人
terryso9 小时前
BMAD Loop:把开发循环的控制权,交还给确定性代码
架构
ASKCOS11 小时前
DeerFlow Agent 中间件架构:用插件化链彻底告别 Agent 继承式开发
中间件·架构
2601_9545267512 小时前
【工控底层架构】进口阀门和国产阀门哪个性价比高?从TCO模型到边缘诊断源码的全栈解析
人工智能·架构·硬件工程
an3174213 小时前
弹窗数据流设计的两种高阶架构实践
前端·vue.js·架构
熊猫钓鱼>_>13 小时前
智能革命的巨浪——AI时代的社会重构与生存之道
大数据·人工智能·重构·架构·llm·agent·ai-native
doiito(Do It Together)13 小时前
我用 Rust 写了个 AI 媒体管家:Gliding Horse 赋能 media_agent,目标是让 ComfyUI 工作流彻底自动化
人工智能·架构·rust·媒体
Xiaoda1113 小时前
vLLM Scheduler:为什么 Continuous Batching 是 LLM Serving 的核心?
架构