Progress

模型上下文协议(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
  }
}
  • progress必须随每次通知增加,即使总计值未知
  • progresstotal可以是浮点数

行为要求

  1. 进度通知必须只引用以下类型的令牌:

    • 在活动请求中提供的令牌
    • 与正在进行的操作相关联的令牌
  2. 进度请求的接收方可以

    • 选择不发送任何进度通知
    • 以他们认为适当的频率发送通知
    • 在未知的情况下省略总计值
Receiver Sender Receiver Sender 带有进度令牌的请求 进度更新 loop [进度更新] 操作完成 带有progressToken的方法请求进度通知 (0.2/1.0)进度通知 (0.6/1.0)进度通知 (1.0/1.0)方法响应

实现说明

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