协议版本: 2024-11-05
- 初始化: 能力协商与协议版本约定
- 操作: 正常协议通信
- 关闭: 优雅地终止连接
生命周期阶段
初始化
The initialization phase 必须 be the first interaction between client and server. During this phase, the client and server:- 建立协议版本兼容性
- 交换和协商能力
- 分享实现细节
initialize request containing:
- 支持的协议版本
- 客户端能力
- 客户端实现信息
initialized notification
to indicate it is ready to begin normal operations:
版本协商
在initialize请求中,客户端必须发送其支持的协议版本。
这应当是客户端支持的最新版本。
如果服务器支持请求的协议版本,它必须以相同版本作出响应。否则,服务器必须以它支持的其他协议版本作出响应。这应当是服务器支持的最新版本。
如果客户端不支持服务器响应中的版本,它应当断开连接。
功能协商
客户端与服务器通过能力协商机制确定会话期间可用的可选协议功能。 主要功能包括:| 类别 | 能力 | 描述 |
|---|---|---|
| 客户端 | roots | 提供文件系统根目录的能力 |
| 客户端 | 采样 | 支持LLM sampling 请求 |
| 客户端 | 实验性的 | 描述对非标准实验性功能的支持 |
| 服务器 | prompts | 提供 提示模版 |
| 服务器 | resources | 提供可读的 resources |
| 服务器 | 工具 | 暴露可调用的工具 |
| 服务器 | 日志 | 发送结构化日志消息 |
| 服务器 | 实验性的 | 描述对非标准实验性功能的支持 |
listChanged: 支持列表更改通知(适用于提示、资源和工具)subscribe: 支持订阅单个项目的更改(仅限资源)
操作
在操作阶段,客户端与服务器根据协商的能力交换消息。 双方 应当:- 遵守协商的协议版本
- 仅使用已成功协商的功能
关闭
在关闭阶段,一方(通常是客户端)会干净利落地终止协议连接。未定义特定的关闭消息——而是应使用底层传输机制来发出连接终止信号:标准输入输出
对于stdio transport传输, 客户端 应当 通过以下方式启动关闭:- 首先,关闭子进程(即服务器)的输入流
- 等待服务器退出,或在合理时间内若服务器未退出则发送
SIGTERM - 如果服务器在收到
SIGTERM后合理时间内没有退出,则发送SIGKILL
超文本传输协议
对于HTTP transports, 关机通过关闭相关的HTTP连接来表示。错误处理
Implementations 应当准备好处理这些错误情况:- 协议版本不匹配
- 失败协商所需功能
- 初始化请求超时
- 关闭超时