模型上下文协议客户端
MCP 客户端是模型上下文协议(MCP)架构中的关键组件,负责与 MCP 服务器建立和管理连接。它实现了协议的客户端部分,处理以下功能:- 协议版本协商以确保与服务器的兼容性
- 能力协商以确定可用功能
- 消息传输和 JSON-RPC 通信
- 工具发现和执行
- 资源访问和管理
- 提示系统交互
- 可选功能,如根目录管理与采样支持
- 同步 API
- 异步 API
客户端传输
传输层处理 MCP 客户端与服务器之间的通信,为各种用例提供不同的实现。客户端传输管理消息序列化、连接建立和协议特定的通信模式。- STDIO
- SSE (HttpClient)
- SSE (WebFlux)
创建用于进程内通信的传输
客户端能力
客户端可以配置各种能力:根目录支持
根目录定义了服务器在文件系统中可以操作的边界:- 请求可访问的文件系统根目录列表
- 接收根目录列表变更的通知
- 了解其可以访问的目录和文件
采样支持
采样使服务器能够通过客户端请求 LLM 交互(“补全”或“生成”):- 服务器利用 AI 能力而无需 API 密钥
- 客户端控制模型访问和权限
- 支持文本和图像交互
- 在提示中可选包含 MCP 服务器上下文
日志支持
客户端可以注册日志消费者以接收服务器的日志消息,并设置最低日志级别以过滤消息:mcpClient.setLoggingLevel(level) 请求控制接收的最低日志级别。低于设定级别的消息将被过滤。
支持的日志级别(按严重程度递增顺序):DEBUG(0)、INFO(1)、NOTICE(2)、WARNING(3)、ERROR(4)、CRITICAL(5)、ALERT(6)、EMERGENCY(7)
使用 MCP 客户端
工具执行
工具是客户端可以发现和执行的服务器端函数。MCP 客户端提供列出可用工具并使用特定参数执行它们的方法。每个工具都有一个唯一名称并接受参数映射。- 同步 API
- 异步 API
资源访问
资源代表客户端可以通过 URI 模板访问的服务器端数据源。MCP 客户端提供通过标准化接口发现可用资源并检索其内容的方法。- 同步 API
- 异步 API
提示系统
提示系统允许与服务器端提示模板交互。这些模板可以被发现并使用自定义参数执行,从而根据预定义模式生成动态文本。- 同步 API
- 异步 API
使用补全
作为 补全能力 的一部分,MCP 提供了标准化方式,使服务器可以为提示和资源 URI 提供参数自动补全建议。 请查看 服务器补全能力 以了解如何在服务器端启用和配置补全功能。 在客户端方面,MCP 客户端提供请求自动补全的方法:- 同步 API
- 异步 API