协议版本: draft
- 初始化: 能力协商与协议版本确认
- 操作: 正常协议通信
- 关机: 该连接的优雅终止
生命周期阶段
初始化
初始化阶段 必须 是客户端与服务器之间的首次交互。 在此阶段,客户端和服务器:- 建立协议版本兼容性
- 交换和协商能力
- 共享实现细节
initialize 请求来启动此阶段:
- 支持的协议版本
- 客户端能力
- 客户端实现信息
initialized通知来表明它已准备好开始正常操作:
版本协商
在initialize请求中,客户端必须发送其支持的协议版本。
这应该是客户端支持的最新版本。
如果服务器支持请求的协议版本,它必须回应相同的版本。否则,服务器必须回应它所支持的另一个协议版本。这应该是服务器支持的最新版本。
如果客户端不支持服务器响应中的版本,它应该断开连接。
如果使用HTTP, 客户端 必须 在所有后续向MCP服务器的请求中包含
MCP-Protocol-Version: HTTP头。
详情请参阅 传输中的协议版本头部分。能力协商
客户端与服务器通过能力协商机制确定会话期间可用的可选协议功能。 主要功能包括:| 类别 | 能力 | 描述 |
|---|---|---|
| 客户端 | roots | 提供文件系统根目录的能力 |
| 客户端 | 采样 | 支持语言模型 sampling 请求 |
| 客户端 | 激发 | 支持服务器启发式请求 |
| 客户端 | 实验性的 | 描述对非标准实验特性的支持情况 |
| 服务器 | 提供 提示模版 | |
| 服务器 | resources | 提供可读的 resources |
| 服务器 | 工具 | 暴露可调用的工具 |
| 服务器 | 日志 | 发送结构化日志消息 |
| 服务器 | completions | 支持参数 autocompletion 功能 |
| 服务器 | 实验性的 | 描述对非标准实验性功能的支持 |
listChanged: 支持列表变更通知(适用于提示、资源和工具)subscribe: 支持订阅单个项目的变更(仅限资源)
操作
在操作阶段,客户端与服务器根据协商的能力交换消息。 双方 必须:- 遵守协商的协议版本
- 仅使用已成功协商的功能
关机
在关闭阶段,一方(通常是客户端)会干净利落地终止协议连接。未定义特定的关闭消息——而是应使用底层传输机制来发出连接终止信号:标准输入输出
对于标准输入输出 transport,客户端应该通过以下方式发起关闭:- 首先,关闭子进程(服务器)的输入流
- 等待服务器退出,或在合理时间内未退出则发送
SIGTERM - 如果服务器在
SIGTERM后的合理时间内未退出,则发送SIGKILL
超文本传输协议
对于 HTTP transports,关闭相关 HTTP 连接即表示关机。超时设置
Implementations 应该 为所有发送的请求设置超时时间,以防止连接挂起和资源枯竭。当请求在超时期间内未收到成功或错误响应时,发送方 应该 为该请求发出一个cancellation notification 并停止等待响应。 SDK以及其他中间件应该允许在每个请求基础上对这些超时进行配置。 实施方 可以 选择在收到与请求对应的进度通知时重置超时时钟,因为这意味着实际工作正在进行。但实施方 应该 始终强制执行最大超时限制,无论是否有进度通知,以限制行为异常的客户端或服务器的影响。错误处理
实现方案应该准备好处理以下错误情况:- 协议版本不匹配
- 未能协商所需能力
- 请求 timeouts