协议修订版本: 2025-03-26
取消流程
当一方希望取消一个进行中的请求时,它将发送一个notifications/cancelled 通知,其中包含:
- 要取消的请求的ID
- 一个可选的原因字符串,可用于记录日志或显示
行为要求
- 取消通知 必须 仅引用以下请求:
- 在同一方向上先前已发出的请求
- 当前认为仍在进行中的请求
initialize请求 不得 被客户端取消- 取消通知的接收方 应该:
- 停止处理被取消的请求
- 释放相关资源
- 不再为被取消的请求发送响应
- 接收方 可以 忽略取消通知,如果:
- 所引用的请求未知
- 处理已经完成
- 该请求无法被取消
- 取消通知的发送方 应该 忽略在那之后到达的、对该请求的任何响应
时序考虑
由于网络延迟,取消通知可能会在请求处理完成之后到达,甚至可能在响应已经发送之后到达。 通信双方 必须 优雅地处理这些竞争情况:实现注意事项
- 通信双方 应该 记录取消原因以便调试
- 应用程序的用户界面 应该 在请求取消时给出提示
错误处理
无效的取消通知 应该 被忽略:- 未知的请求ID
- 已完成的请求
- 格式错误的通知