取消工作流运行时,你可能正在运行使用与该工作流运行相关的资源的其他软件。 为了帮助您释放与工作流程运行相关的资源,它可能有助于了解 GitHub 为取消工作流程运行而执行的步骤。
- 要取消工作流运行,服务器将重新评估所有正在运行的作业的 if条件。 如果条件评估为true,作业将不会取消。 例如,条件if: always()评估为 true,作业继续运行。 没有条件时,则等同于条件if: success(),仅在上一步已成功完成时才会运行。
- 对于需要取消的作业,服务器向包含需取消作业的所有运行器机器发送取消消息。
- 对于继续运行的作业,服务器将对未完成的步骤重新评估 if条件。 如果条件评估为true,则步骤继续运行。 可以使用cancelled表达式来应用cancelled()状态检查。 有关详细信息,请参阅“对工作流和操作中的表达式求值”。
- 对于需要取消的步骤,运行器计算机会将 SIGINT/Ctrl-C发送到步骤的入口进程(对于 JavaScript 操作,为node;对于容器操作,为docker;在步骤中使用run时,为bash/cmd/pwd)。 如果进程未在 7500 毫秒内退出,运行器将发送SIGTERM/Ctrl-Break到此进程,然后等待 2500 毫秒让进程退出。 如果该进程仍在运行,运行器会停止进程树。
- 在 5 分钟取消超时期后,服务器将强制终止仍在运行的所有作业和步骤。