协议修订:2025-03-26
- 初始化:能力协商和协议版本协商
- 运行:正常协议通信
- 关闭:连接的优雅终止
生命周期阶段
初始化
初始化阶段 必须 是客户端和服务端之间的首次交互。在此阶段,客户端和服务端:- 建立协议版本兼容性
- 交换并协商能力
- 共享实现细节
initialize 请求来启动此阶段:
- 支持的协议版本
- 客户端能力
- 客户端实现信息
initialize 请求 不能 是 JSON-RPC 批处理 的一部分,因为在初始化完成之前无法进行其他请求和通知。这也允许向后兼容不显式支持 JSON-RPC 批处理的旧协议版本。
服务端 必须 以其自身的能力和信息进行响应:
initialized 通知,表示其已准备好开始正常操作:
版本协商
在initialize 请求中,客户端 必须 发送其支持的协议版本。该版本 应该 是客户端支持的 最新 版本。
如果服务器支持请求的协议版本,则 必须 返回相同的版本。否则,服务器 必须 返回其支持的另一个版本。该版本 应该 是服务器支持的 最新 版本。
如果客户端不支持服务器响应中的版本,它 应该 断开连接。
能力协商
客户端和服务端的能力确定了会话期间可用的可选协议特性。 关键能力包括:
能力对象可以描述子能力,例如:
listChanged: 支持列表变更通知(适用于提示、资源和工具)subscribe: 支持订阅单个项目的变更(仅限资源)
操作
在操作阶段,客户端和服务端根据协商的能力交换消息。 双方 应该:- 遵守协商的协议版本
- 仅使用已成功协商的能力
关闭
在关闭阶段,一方(通常是客户端)优雅地终止协议连接。未定义特定的关闭消息——相反,应使用底层传输机制来指示连接终止:stdio
对于 传输 使用 stdio 的情况,客户端 应该 通过以下方式启动关闭:- 首先,关闭子进程(服务器)的输入流
- 等待服务器退出,或在服务器未在合理时间内退出时发送
SIGTERM - 如果服务器在
SIGTERM后仍未在合理时间内退出,则发送SIGKILL
HTTP
对于 HTTP 传输,关闭通过关闭相关的 HTTP 连接来表示。超时
实现 应该 为所有发送的请求设置超时机制,以防止连接挂起和资源耗尽。当请求在超时时间内未收到成功或错误响应时,发送方 应该 发送一个 取消通知 并停止等待响应。 SDK 和其他中间件 应该 允许按每个请求配置这些超时。 实现 可以 在接收到与请求对应的 进度通知 时重置超时计时器,因为这表明工作正在进行。然而,实现 应该 始终强制设置最大超时时间,无论是否有进度通知,以限制行为异常的客户端或服务端的影响。错误处理
实现 应该 准备处理以下错误情况:- 协议版本不匹配
- 无法协商所需能力
- 请求 超时