- 初始化:能力协商和协议版本达成一致
- 运行:正常的协议通信
- 关闭:优雅地终止连接
生命周期阶段
初始化
初始化阶段 必须 是客户端和服务器之间的第一次交互。在此阶段,客户端和服务器:- 建立协议版本兼容性
- 交换和协商能力
- 共享实现细节
initialize 请求来发起此阶段:
- 支持的协议版本
- 客户端能力
- 客户端实现信息
initialized 通知,表明已准备好开始正常操作:
- 在服务器响应
initialize请求之前,客户端 不应 发送除 ping 请求 之外的请求。 - 在收到
initialized通知之前,服务器 不应 发送除 ping 请求 和 日志 之外的请求。
版本协商
在initialize 请求中,客户端 必须 发送其支持的协议版本。这 应 是客户端支持的 最新 版本。
如果服务器支持请求的协议版本,它 必须 响应相同的版本。否则,服务器 必须 响应其支持的另一个协议版本。这 应 是服务器支持的 最新 版本。
如果客户端不支持服务器响应中的版本,它 应 断开连接。
如果使用 HTTP,客户端 必须 在后续所有对 MCP 服务器的请求中包含
MCP-Protocol-Version: <protocol-version> HTTP 头。
详细信息请参阅 传输中的协议版本头部分。能力协商
客户端和服务器能力确立了会话期间哪些可选协议功能可用。 关键能力包括:
能力对象可以描述子能力,例如:
listChanged:支持列表变更通知(适用于提示、资源和工具)subscribe:支持订阅单个项目的变更(仅适用于资源)
运行
在运行阶段,客户端和服务器根据协商的能力交换消息。 双方 必须:- 遵守协商的协议版本
- 仅使用成功协商的能力
关闭
在关闭阶段,一方(通常是客户端)干净地终止协议连接。没有定义特定的关闭消息——相反,应使用底层传输机制来信号连接终止:stdio
对于 stdio 传输,客户端 应 通过以下方式发起关闭:- 首先,关闭到子进程(服务器)的输入流
- 等待服务器退出,或者如果服务器未在合理时间内退出则发送
SIGTERM - 如果服务器在
SIGTERM后的合理时间内未退出,则发送SIGKILL
HTTP
对于 HTTP 传输,关闭通过关闭关联的 HTTP 连接来指示。超时
实现 应 为所有发送的请求建立超时,以防止连接挂起和资源耗尽。当请求在超时期限内未收到成功或错误响应时,发送者 应 为该请求发出 取消通知 并停止等待响应。 SDK 和其他中间件 应 允许按请求基础配置这些超时。 实现 可以 选择在收到对应于请求的 进度通知 时重置超时时钟,因为这意味着工作实际上正在进行。但是,无论进度通知如何,实现 应 始终强制最大超时,以限制行为不当的客户端或服务器的影响。错误处理
实现 应 准备好处理这些错误情况:- 协议版本不匹配
- 无法协商所需的能力
- 请求 超时