协议修订: 2025-03-26
- 初始化:能力协商和协议版本协议
- 操作:正常协议通信
- 关闭:连接的优雅终止
生命周期阶段
初始化
初始化阶段必须是客户端和服务器之间的第一次交互。在此阶段,客户端和服务器:- 建立协议版本兼容性
- 交换和协商能力
- 共享实现细节
initialize请求来启动此阶段:
- 支持的协议版本
- 客户端能力
- Client implementation information
initialized通知以表明它已准备好开始正常操作:
版本协商
在initialize请求中,客户端必须发送它支持的协议版本。这应该是客户端支持的_最新_版本。
如果服务器支持请求的协议版本,它必须以相同版本响应。否则,服务器必须以它支持的另一个协议版本响应。这应该是服务器支持的_最新_版本。
如果客户端不支持服务器响应中的版本,它应该断开连接。
能力协商
客户端和服务器能力建立会话期间哪些可选协议功能将可用。 关键能力包括:
Capability objects can describe sub-capabilities like:
listChanged: Support for list change notifications (for prompts, resources, and tools)subscribe: Support for subscribing to individual items’ changes (resources only)
Operation
在操作阶段,客户端和服务器根据协商的能力交换消息。 双方应该:- 遵守协商的协议版本
- 仅使用成功协商的能力
关闭
在关闭阶段,一方(通常是客户端)干净地终止协议连接。没有定义特定的关闭消息——相反,应该使用底层传输机制来发出连接终止信号:stdio
对于stdio传输,客户端应该通过以下方式启动关闭:- 首先,关闭到子进程(服务器)的输入流
- 等待服务器退出,或者如果服务器在合理时间内没有退出则发送
SIGTERM - 如果服务器在
SIGTERM后在合理时间内没有退出,则发送SIGKILL
HTTP
对于HTTP传输,关闭通过关闭关联的HTTP连接来指示。超时
实现应该为所有发送的请求建立超时,以防止挂起的连接和资源耗尽。当请求在超时时间内没有收到成功或错误响应时,发送者应该为该请求发出取消通知并停止等待响应。 SDK和其他中间件应该允许在每个请求的基础上配置这些超时。 实现可以选择在接收到对应于请求的进度通知时重置超时时钟,因为这意味着工作实际上正在进行。但是,实现应该始终强制执行最大超时,无论进度通知如何,以限制行为不端的客户端或服务器的影响。错误处理
实现应该准备处理这些错误情况:- 协议版本不匹配
- 无法协商所需能力
- 请求超时