协议修订日期: 2024-11-05
取消流程
当某一方希望取消一个进行中的请求时,它将发送一个notifications/cancelled 通知,其中包含:
- 要取消的请求的 ID
- 一个可选的描述字符串,可用于记录日志或显示
行为要求
- 取消通知只能引用以下请求:
- 之前在同一方向上发出的请求
- 当前被认为仍在进行中的请求
- 客户端不得取消
initialize请求 - 接收到取消通知的一方应该:
- 停止处理被取消的请求
- 释放相关资源
- 不再为被取消的请求发送响应
- 接收方可以忽略以下情况的取消通知:
- 请求 ID 未知
- 请求处理已经完成
- 请求无法被取消
- 发送取消通知的一方应该忽略之后收到的该请求的响应
时序考虑
由于网络延迟,取消通知可能在请求处理完成后才到达,甚至可能在响应已经发送之后才到达。 双方必须优雅地处理这些竞态条件:实现建议
- 双方应该记录取消原因以供调试
- 应用界面应该在请求被取消时作出相应提示
错误处理
对于无效的取消通知,应该忽略:- 未知的请求 ID
- 已完成的请求
- 格式错误的通知