K8s中的pod的终止过程

当用户提交删除请求之后,系统就会进行强制删除操作的宽限期倒计时,并将TERM信息发送给 pod对象的每个容器中的主进程。宽限期倒计时结束后,这些进程将收到强制终止的KILL信号,pod对 象随即也将由api server删除,如果在等待进程终止的过程中,kubelet或容器管理器发生了重启,那么 终止操作会重新获得一个满额的删除宽限期并重新执行删除操作。

一个典型的pod对象终止流程具体如下:

1. 用户发送删除pod对象的命令

2. api服务器中的pod对象会随着时间的推移而更新,在宽限期内(默认30s),pod被视为dead

3. 将pod标记为terminating状态

4. 与第三步同时运行,kubelet在监控到pod对象转为terminating状态的同时启动pod关闭过程

5. 与第三步同时运行,端点控制器监控到pod对象的关闭行为时将其从所有匹配到此端点的service 资源的端点列表中移除

6. 如果当前pod对象定义了preStop钩子处理器,则在其标记为terminating后即会以同步的方式启动 执行;若宽限期结束后,preStop仍未执行结束,则第二步会被重新执行并额外获取一个时长为2s 的小宽限期

7. pod对象中的容器进程收到TERM信号

8. 宽限期结束后,若存在任何一个仍在运行的进程,那么pod对象即会收到SIGKILL信号

9. kubelet请求api server将此pod资源的宽限期设置为0从而完成删除操作,它变得对用户不再可 见。

默认情况下,所有删除操作的宽限期都是30s,不过,kubectl delete命令可以使用“--grace-period=”选 项自定义其时长,若使用0值则表示直接强制删除指定的资源,不过此时需要同时使用命令“--forece”选 项

你可能感兴趣的:(K8S,运维,容器,微服务)