Skip to main content
协议版本: 2025-03-26
模型上下文协议(MCP)通过通知消息支持对长时间运行操作的可选进度跟踪。任何一方都可以发送进度通知,提供有关操作状态的更新。

进度流程

当一方想要为请求_接收_进度更新时,它在请求元数据中包含一个progressToken
  • 进度令牌必须是字符串或整数值
  • 进度令牌可以由发送者使用任何方式选择,但必须在所有活动请求中唯一。
{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "some_method",
  "params": {
    "_meta": {
      "progressToken": "abc123"
    }
  }
}
接收者可以然后发送包含以下内容的进度通知:
  • 原始进度令牌
  • 到目前为止的当前进度值
  • 可选的”总计”值
  • 可选的”消息”值
{
  "jsonrpc": "2.0",
  "method": "notifications/progress",
  "params": {
    "progressToken": "abc123",
    "progress": 50,
    "total": 100,
    "message": "正在重新计算样条..."
  }
}
  • progress必须随着每个通知而增加,即使总计未知。
  • progresstotal可以是浮点数。
  • message字段应该提供相关的人类可读进度信息。

行为要求

  1. 进度通知必须只引用以下令牌:
    • 在活动请求中提供的令牌
    • 与正在进行的操作相关联的令牌
  2. 进度请求的接收者可以
    • 选择不发送任何进度通知
    • 以他们认为适当的频率发送通知
    • 如果未知,则省略总计值

实现注意事项

  • 发送者和接收者应该跟踪活动进度令牌
  • 双方应该实施速率限制以防止泛滥
  • 完成后进度通知必须停止