取消流程
当一方想要取消一个进行中的请求时,它会发送一个notifications/cancelled 通知,包含:
- 要取消的请求的 ID
- 一个可选的原因字符串,可以被记录或显示
行为要求
- 取消通知 MUST 仅引用以下请求:
- 之前在同一方向发出的
- 被认为仍在进行中的
- 客户端 MUST NOT 取消
initialize请求 - 取消通知的接收者 SHOULD:
- 停止处理被取消的请求
- 释放相关资源
- 不为被取消的请求发送响应
- 如果出现以下情况,接收者 MAY 忽略取消通知:
- 引用的请求未知
- 处理已经完成
- 请求无法被取消
- 取消通知的发送者 SHOULD 忽略随后到达的对该请求的任何响应
时序考虑
由于网络延迟,取消通知可能在请求处理完成后到达,甚至可能在响应已经发送之后到达。 双方 MUST 优雅地处理这些竞争条件:实现说明
- 双方 SHOULD 记录取消原因以便调试
- 应用程序 UI SHOULD 指示何时请求了取消
错误处理
无效的取消通知 SHOULD 被忽略:- 未知的请求 ID
- 已完成的请求
- 格式错误的通知