模型上下文协议(MCP)
模型上下文协议(MCP)是一个标准化协议,使 AI 模型能够以结构化的方式与外部工具和资源交互。 它支持多种传输机制,以在不同环境中提供灵活性。
MCP Java SDK 提供了模型上下文协议的 Java 实现,通过同步和异步通信模式实现与 AI 模型和工具的标准化交互。
Spring AI MCP
通过 Spring Boot 集成扩展了 MCP Java SDK,提供了 客户端 和 服务器 启动器。
使用 Spring Initializer 引导具有 MCP 支持的 AI 应用程序。
MCP Java SDK 0.8.0 中的重大变更 ⚠️ MCP Java SDK 0.8.0 版本引入了几个重大变更,包括新的基于会话的架构。如果您正在从 Java SDK 0.7.0 升级,请参阅 迁移指南 获取详细说明。 |
MCP Java SDK 架构
提示:本节提供了 MCP Java SDK 架构 的概述。 对于 Spring AI MCP 集成,请参阅 Spring AI MCP 启动器 文档。
Java MCP 实现遵循三层架构:
|
MCP 客户端 | |
---|---|
MCP 客户端是模型上下文协议(MCP)架构中的关键组件,负责建立和管理与 MCP 服务器的连接。它实现了协议的客户端部分,处理:
|
![]() |
MCP 服务器 | |
---|---|
MCP 服务器是模型上下文协议(MCP)架构中的基础组件,为客户端提供工具、资源和功能。它实现了协议的服务器端,负责:
|
![]() |
有关使用低级 MCP 客户端/服务器 API 的详细实现指南,请参阅 MCP Java SDK 文档。 对于使用 Spring Boot 的简化设置,请使用下面描述的 MCP 启动器。
Spring AI MCP 集成
Spring AI 通过以下 Spring Boot 启动器提供 MCP 集成:
客户端启动器
-
spring-ai-starter-mcp-client
- 提供 STDIO 和基于 HTTP 的 SSE 支持的核心启动器 -
spring-ai-starter-mcp-client-webflux
- 基于 WebFlux 的 SSE 传输实现
服务器启动器
-
spring-ai-starter-mcp-server
- 具有 STDIO 传输支持的核心服务器 -
spring-ai-starter-mcp-server-webmvc
- 基于 Spring MVC 的 SSE 传输实现 -
spring-ai-starter-mcp-server-webflux
- 基于 WebFlux 的 SSE 传输实现