当使用 Kubernetes 的 kubectl delete pod 命令删除一个 Pod 时,Kubernetes 控制平面会向相应的 Pod 发送一个删除请求。Pod 中的进程退出的具体行为取决于该进程的处理逻辑和信号处理方式。
下面是一般情况下 Pod 中进程退出的处理过程:
-
删除请求发送:Kubernetes 控制平面接收到删除请求后,会向 Pod 发送一个删除信号。
-
Termination Grace Period(终止优雅期):Pod 的 Termination Grace Period 开始。这是一个时间段,在这段时间内,Kubernetes 会等待 Pod 中的进程进行清理和退出操作。默认情况下,Termination Grace Period 的长度为 30 秒,可以通过 Pod 的 terminationGracePeriodSeconds 字段进行配置。
-
信号发送:在 Termination Grace Period 内,Kubernetes 会向 Pod 中的主进程发送 SIGTERM 信号(15号信号),用于请求进程进行优雅的退出。
-
进程处理:进程收到 SIGTERM 信号后,根据进程的信号处理方式进行处理。进程可以选择在接收到信号后进行一些清理工作,例如保存数据、关闭连接、释放资源等。
-
终止超时:如果在 Termination Grace Period结束之前进程仍然未退出,Kubernetes 将发送 SIGKILL 信号(9号信号)给进程,强制终止进程。这意味着进程将被立即终止,无法再进行任何清理操作。
总之,Pod 中的进程必须正确处理接收到的信号,以实现优雅的退出。如果进程没有正确处理信号,可能会导致数据丢失、连接断开或其他异常情况。因此,建议在编写容器应用程序时,确保进程能够正确地处理 SIGTERM 信号,以实现优雅的退出行为。