协议修订:2024-11-05
- 初始化:能力协商和协议版本协商
- 运行:正常的协议通信
- 关闭:连接的优雅终止
生命周期阶段
初始化
初始化阶段必须是客户端与服务器之间的首次交互。在此阶段,客户端和服务器:- 建立协议版本兼容性
- 交换并协商能力
- 共享实现细节
initialize 请求来启动此阶段:
- 支持的协议版本
- 客户端能力
- 客户端实现信息
initialized 通知以表明它已准备好开始正常操作:
版本协商
在initialize 请求中,客户端必须发送其支持的协议版本。该版本应该是客户端支持的最新版本。
如果服务器支持请求的协议版本,则必须以相同的版本响应;否则,服务器必须以它支持的其他协议版本进行响应。该版本应该是服务器支持的最新版本。
如果客户端不支持服务器响应中的版本,它应该断开连接。
能力协商
客户端和服务器的能力定义了会话期间可用的可选协议特性。 关键能力包括:
能力对象可以描述子能力,例如:
listChanged:支持列表变更通知(用于提示、资源和工具)subscribe:支持订阅单个条目变更(仅资源)
运行
在运行阶段,客户端和服务器根据协商的能力交换消息。 双方应该:- 遵守协商的协议版本
- 仅使用成功协商的能力
关闭
在关闭阶段,一方(通常是客户端)干净地终止协议连接。没有定义特定的关闭消息——而是使用底层传输机制来表示连接终止:stdio
对于 stdio 传输,客户端应该通过以下方式启动关闭:- 首先,关闭子进程(服务器)的输入流
- 等待服务器退出,或在服务器未在合理时间内退出时发送
SIGTERM - 如果在发送
SIGTERM后服务器仍未在合理时间内退出,则发送SIGKILL
HTTP
对于 HTTP 传输,关闭通过关闭相关的 HTTP 连接来表示。错误处理
实现应该准备处理以下错误情况:- 协议版本不匹配
- 无法协商必需的能力
- 初始化请求超时
- 关闭超时