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