MCP调用流程图

组件关系 Excel MCP Server ExcelMCPClient McpExcelToolDiscoveryService McpExcelToolConfig DefaultToolRegistry OpenAiChatModel ToolCallingManager 工具调用阶段 需要工具调用 不需要工具调用 OpenAiChatModel处理 大模型请求 ToolCallingManager判断是否需要工具调用 匹配可用工具 调用ExcelMCPClient.callTool 构建SSE请求 发送到Excel MCP Server 接收SSE响应 解析工具执行结果 返回给OpenAiChatModel 生成最终响应 启动阶段 Spring容器初始化 应用启动 McpExcelToolDiscoveryService初始化 调用MCP Server的/capabilities接口 解析工具元数据 存储工具定义到Map McpExcelToolConfig初始化 注入McpExcelToolDiscoveryService 获取所有工具定义 注册工具到DefaultToolRegistry OpenAiModelConfig初始化 创建ToolCallingManager 创建OpenAiChatModel

流程图说明

启动阶段

  1. 应用启动:Spring Boot应用程序启动
  2. Spring容器初始化:创建并初始化所有Spring Bean
  3. McpExcelToolDiscoveryService初始化
    • 调用MCP Server的/capabilities接口获取工具元数据
    • 解析并存储工具定义到内部Map中
  4. McpExcelToolConfig初始化
    • 注入McpExcelToolDiscoveryService
    • 获取所有工具定义并注册到DefaultToolRegistry
  5. OpenAiModelConfig初始化
    • 创建ToolCallingManager
    • 创建OpenAiChatModel并配置ToolCallingManager

工具调用阶段

  1. 大模型请求:用户发送请求到应用程序
  2. OpenAiChatModel处理:接收并处理请求
  3. ToolCallingManager判断:判断是否需要调用工具
  4. 工具匹配:如果需要调用工具,匹配可用的工具
  5. ExcelMCPClient调用:调用ExcelMCPClient的callTool方法
  6. 构建SSE请求:构建Server-Sent Events请求
  7. 发送请求:发送请求到Excel MCP Server
  8. 接收响应:接收SSE响应
  9. 解析结果:解析工具执行结果
  10. 返回结果:将结果返回给OpenAiChatModel
  11. 生成响应:生成最终响应返回给用户

组件关系

  • ExcelMCPClient:与Excel MCP Server通信的客户端
  • McpExcelToolDiscoveryService:动态发现Excel MCP Server的工具
  • McpExcelToolConfig:将动态工具注册到Spring AI中
  • OpenAiChatModel:处理大模型请求
  • ToolCallingManager:管理工具调用
  • DefaultToolRegistry:注册和管理所有可用工具
  • Excel MCP Server:外部服务,提供Excel操作工具

技术要点

  1. 动态工具发现:通过调用MCP Server的/capabilities接口动态获取工具定义
  2. 工具注册:将动态发现的工具注册到Spring AI的DefaultToolRegistry
  3. SSE通信:使用Server-Sent Events与Excel MCP Server通信
  4. 异步处理:使用AtomicReference和CountDownLatch处理异步响应
  5. 超时控制:设置超时机制确保请求不会无限等待

配置说明

  • application.yml中配置Excel MCP Server的URL和超时时间
  • bootstrap.yml中设置allow-bean-definition-overriding: true允许Bean定义覆盖
  • 通过McpExcelToolConfig控制工具的注册和管理

这个流程图清晰地展示了从应用启动到工具调用的完整流程,包括各个组件之间的关系和交互方式。

相关推荐
程序员清风15 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林55116 小时前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊1 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing1 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠2 天前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840822 天前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide2 天前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家2 天前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺2 天前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户908324602732 天前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端