K8s中的pod的终止过程

30 篇文章 1 订阅

当用户提交删除请求之后,系统就会进行强制删除操作的宽限期倒计时,并将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”选 项

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值