Skip to main content
协议修订: 2025-03-26
Model Context Protocol (MCP) 为客户端-服务器连接定义了严格的生命周期,确保适当的能力协商和状态管理。
  1. 初始化:能力协商和协议版本协议
  2. 操作:正常协议通信
  3. 关闭:连接的优雅终止

生命周期阶段

初始化

初始化阶段必须是客户端和服务器之间的第一次交互。在此阶段,客户端和服务器:
  • 建立协议版本兼容性
  • 交换和协商能力
  • 共享实现细节
客户端必须通过发送包含以下内容的initialize请求来启动此阶段:
  • 支持的协议版本
  • 客户端能力
  • Client implementation information
{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "initialize",
  "params": {
    "protocolVersion": "2025-03-26",
    "capabilities": {
      "roots": {
        "listChanged": true
      },
      "sampling": {}
    },
    "clientInfo": {
      "name": "ExampleClient",
      "version": "1.0.0"
    }
  }
}
initialize请求不能是JSON-RPC批处理的一部分,因为在初始化完成之前,其他请求和通知是不可能的。这也允许与不明确支持JSON-RPC批处理的先前协议版本向后兼容。 服务器必须使用自己的能力和信息进行响应:
{
  "jsonrpc": "2.0",
  "id": 1,
  "result": {
    "protocolVersion": "2025-03-26",
    "capabilities": {
      "logging": {},
      "prompts": {
        "listChanged": true
      },
      "resources": {
        "subscribe": true,
        "listChanged": true
      },
      "tools": {
        "listChanged": true
      }
    },
    "serverInfo": {
      "name": "ExampleServer",
      "version": "1.0.0"
    },
    "instructions": "Optional instructions for the client"
  }
}
成功初始化后,客户端必须发送initialized通知以表明它已准备好开始正常操作:
{
  "jsonrpc": "2.0",
  "method": "notifications/initialized"
}
  • 客户端不应该在服务器响应initialize请求之前发送除ping之外的其他请求。
  • 服务器不应该在接收到initialized通知之前发送除pinglogging之外的请求。

版本协商

initialize请求中,客户端必须发送它支持的协议版本。这应该是客户端支持的_最新_版本。 如果服务器支持请求的协议版本,它必须以相同版本响应。否则,服务器必须以它支持的另一个协议版本响应。这应该是服务器支持的_最新_版本。 如果客户端不支持服务器响应中的版本,它应该断开连接。

能力协商

客户端和服务器能力建立会话期间哪些可选协议功能将可用。 关键能力包括:
类别能力描述
客户端roots提供文件系统根目录的能力
客户端sampling支持LLM采样请求
客户端experimental描述对非标准实验性功能的支持
服务器prompts提供提示模板
服务器resources提供可读的资源
服务器tools公开可调用的工具
服务器logging发出结构化的日志消息
服务器completions支持参数自动完成
ServerexperimentalDescribes support for non-standard experimental features
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传输,客户端应该通过以下方式启动关闭:
  1. 首先,关闭到子进程(服务器)的输入流
  2. 等待服务器退出,或者如果服务器在合理时间内没有退出则发送SIGTERM
  3. 如果服务器在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"
    }
  }
}