模型上下文协议(MCP协议)客户端
MCP客户端是模型上下文协议(MCP协议)架构中的关键组件,负责建立和管理与MCP服务器的连接。它实现了协议的客户端部分,处理以下任务:- 协议版本协商以确保与服务器的兼容性
- 能力协商以确定可用功能
- 消息传输和JSON-RPC通信
- 工具发现与执行
- 资源访问与管理
- 提示系统交互
- 可选功能,如根目录管理和采样支持
- 同步API
- 异步API
客户端传输
传输层负责MCP客户端与服务器之间的通信,为不同的用例提供了多种实现。客户端传输管理消息序列化、连接建立和协议特定的通信模式。- STDIO
- SSE (HttpClient)
- SSE (WebFlux)
创建用于进程内通信的传输
客户端能力
客户端可以配置多种能力:根目录支持
根目录定义了服务器可以在文件系统中操作的边界:- 请求可访问的文件系统根目录列表
- 接收根目录列表变更的通知
- 了解哪些目录和文件是可访问的
采样支持
采样使服务器能够通过客户端请求LLM交互(“补全”或“生成”):- 服务器无需API密钥即可利用AI能力
- 客户端保持对模型访问和权限的控制
- 支持文本和图像交互
- 可选地在提示中包含MCP服务器上下文
使用MCP客户端
工具执行
工具是服务器端的功能,客户端可以发现并执行它们。MCP客户端提供了列出可用工具并使用特定参数执行它们的方法。每个工具都有唯一的名称并接受参数映射。- 同步API
- 异步API
资源访问
资源代表服务器端的数据源,客户端可以使用URI模板访问它们。MCP客户端提供了发现可用资源并通过标准化接口检索其内容的方法。- 同步API
- 异步API
提示系统
提示系统支持与服务器端提示模板的交互。这些模板可以被发现并使用自定义参数执行,从而基于预定义的模式生成动态文本。- 同步API
- 异步API