Documentation Index
Fetch the complete documentation index at: https://mcp.gjxx.dev/llms.txt
Use this file to discover all available pages before exploring further.
Model Context Protocol (MCP)为客户端-服务器连接定义了严格的生命周期,确保正确的功能协商和状态管理。
- 初始化:功能协商和协议版本协商
- 操作:正常的协议通信
- 关闭:连接的优雅终止
生命周期阶段
初始化
初始化阶段必须是客户端和服务器之间的第一次交互。在此阶段,客户端和服务器:
客户端必须通过发送包含以下内容的initialize请求来启动此阶段:
{
"jsonrpc": "2.0",
"id": 1,
"method": "initialize",
"params": {
"protocolVersion": "2024-11-05",
"capabilities": {
"roots": {
"listChanged": true
},
"sampling": {},
"elicitation": {}
},
"clientInfo": {
"name": "ExampleClient",
"title": "Example Client Display Name",
"version": "1.0.0",
"icons": [
{
"src": "https://example.com/icon.png",
"mimeType": "image/png",
"sizes": ["48x48"]
}
],
"websiteUrl": "https://example.com"
}
}
}
服务器必须使用自己的功能和信息进行响应:
{
"jsonrpc": "2.0",
"id": 1,
"result": {
"protocolVersion": "2024-11-05",
"capabilities": {
"logging": {},
"prompts": {
"listChanged": true
},
"resources": {
"subscribe": true,
"listChanged": true
},
"tools": {
"listChanged": true
}
},
"serverInfo": {
"name": "ExampleServer",
"title": "Example Server Display Name",
"version": "1.0.0",
"icons": [
{
"src": "https://example.com/server-icon.svg",
"mimeType": "image/svg+xml",
"sizes": ["any"]
}
],
"websiteUrl": "https://example.com/server"
},
"instructions": "Optional instructions for the client"
}
}
成功初始化后,客户端必须发送initialized通知以表明它已准备好开始正常操作:
{
"jsonrpc": "2.0",
"method": "notifications/initialized"
}
- 客户端不应该在服务器响应
initialize请求之前发送除ping以外的请求。
- 服务器不应该在接收到
initialized通知之前发送除ping和logging以外的请求。
版本协商
在initialize请求中,客户端必须发送它支持的协议版本。这应该是客户端支持的_最新_版本。
如果服务器支持请求的协议版本,它必须使用相同版本进行响应。否则,服务器必须使用它支持的另一个协议版本进行响应。这应该是服务器支持的_最新_版本。
如果客户端不支持服务器响应中的版本,它应该断开连接。
如果使用HTTP,客户端必须在所有后续对MCP服务器的请求中包含MCP-Protocol-Version: <protocol-version> HTTP头。
有关详细信息,请参阅传输中的协议版本头部分。
功能协商
客户端和服务器功能建立在会话期间哪些可选协议功能将可用。
关键功能包括:
| 类别 | 功能 | 描述 |
|---|
| 客户端 | roots | 提供文件系统根目录的能力 |
| 客户端 | sampling | 支持LLM采样请求 |
| 客户端 | elicitation | 支持服务器引出请求 |
| 客户端 | experimental | 描述对非标准实验性功能的支持 |
| 服务器 | prompts | 提供提示模板 |
| 服务器 | resources | 提供可读资源 |
| 服务器 | tools | 公开可调用的工具 |
| 服务器 | logging | 发出结构化的日志消息 |
| 服务器 | completions | 支持参数自动完成 |
| 服务器 | experimental | 描述对非标准实验性功能的支持 |
功能对象可以描述子功能,如:
listChanged:支持列表更改通知(针对提示、资源和工具)
subscribe:支持订阅单个项目的更改(仅限资源)
在操作阶段,客户端和服务器根据协商的功能交换消息。
双方必须:
在关闭阶段,一方(通常是客户端)干净地终止协议连接。没有定义特定的关闭消息——相反,应该使用底层传输机制来发出连接终止信号:
stdio
对于stdio传输,客户端应该通过以下方式启动关闭:
- 首先,关闭到子进程(服务器)的输入流
- 等待服务器退出,或者如果服务器在合理时间内没有退出则发送
SIGTERM
- 如果服务器在
SIGTERM后在合理时间内没有退出,则发送SIGKILL
服务器可以通过关闭到客户端的输出流并退出而启动关闭。
HTTP
对于HTTP传输,关闭通过关闭关联的HTTP连接来指示。
实现应该为所有发送的请求建立超时,以防止挂起的连接和资源耗尽。当请求在超时期间内没有收到成功或错误响应时,发送方应该为该请求发出取消通知并停止等待响应。
SDK和其他中间件应该允许在每个请求的基础上配置这些超时。
实现可以选择在接收到对应于请求的进度通知时重置超时时钟,因为这意味着工作实际上正在进行。但是,实现应该始终强制执行最大超时,无论进度通知如何,以限制行为不端的客户端或服务器的影响。
错误处理
实现应该准备处理这些错误情况:
初始化错误示例:
{
"jsonrpc": "2.0",
"id": 1,
"error": {
"code": -32602,
"message": "Unsupported protocol version",
"data": {
"supported": ["2024-11-05"],
"requested": "1.0.0"
}
}
}