取消操作
协议修订版:2024-11-05
模型上下文协议(MCP)支持通过通知消息对进行中的请求进行可选取消。任一方均可发送取消通知,以指示应终止先前发出的请求。
取消流程
当一方希望取消进行中的请求时,它会发送 notifications/cancelled
通知,包含以下内容:
- 要取消的请求的 ID
- 可选的理由字符串,可用于记录或显示
{
"jsonrpc": "2.0",
"method": "notifications/cancelled",
"params": {
"requestId": "123",
"reason": "用户请求取消"
}
}
行为要求
- 取消通知 必须 仅引用满足以下条件的请求:
- 客户端 不得 取消
initialize
请求
- 接收取消通知的一方 应该:
- 停止处理被取消的请求
- 释放相关资源
- 不为被取消的请求发送响应
- 接收方 可以 忽略取消通知,如果:
- 发送取消通知的一方 应该 忽略随后到达的该请求的任何响应
时间考虑
由于网络延迟,取消通知可能在请求处理完成后到达,甚至可能在响应已发送后到达。
双方 必须 优雅地处理这些竞争条件:
sequenceDiagram
participant Client
participant Server
Client->>Server: 请求 (ID: 123)
Note over Server: 开始处理
Client--)Server: notifications/cancelled (ID: 123)
alt
Note over Server: 处理可能在<br/>取消通知到达前<br/>已完成
else 如果未完成
Note over Server: 停止处理
end
实现注意事项
- 双方 应该 记录取消理由以便调试
- 应用程序 UI 应该 在请求取消时进行指示
错误处理
无效的取消通知 应该 被忽略:
这保持了通知的“发送后无需确认”特性,同时允许异步通信中的竞争条件。