Kubernetes----Pod生命周期简介

本文详细介绍了Kubernetes中Pod的生命周期,包括创建过程(从提交信息到容器运行)、终止过程(从删除命令到完全终止)以及Pod的五种状态。在创建过程中,涉及了scheduler、kubelet和容器启动的各个阶段;在终止过程中,描述了从接收到删除命令到容器优雅关闭的步骤。此外,还提到了初始化容器、存活性和就绪性探测等关键概念。
摘要由CSDN通过智能技术生成

【原文链接】

一、Pod生命周期简介

一般将pod对象从创建至终止的这段时间范围称为pod的盛名周期,它主要包含下面的过程:

  • pod创建过程
  • 运行初始化容器(init container)过程
  • 运行注容器(main container)过程
    • 容器启动后钩子(post start),容器终止前钩子(pre stop)
    • 容器的存活性探测(liveness probe),就绪性探测(readness probe)
  • pod终止过程
    在这里插入图片描述

在整个声明周期中,Pod会出现5种状态(相位),如下:

  • 挂起(Pending):挨批server已经创建了pod资源对象,但它尚未被调度完成或者仍处于下载镜像的过程中
  • 运行中(Running):pod已经被调度至某节点,并且所有容器都已经被kubectl创建完成
  • 成功(Succeed):pod中的所有容器都已经成功终止并且不会被重启
  • 失败(Failed):所有容器都已经停止,但至少有一个容器终止失败,即容器返回了非0的退出状态
  • 未知(Unknown):apiserver无法正常获取到pod对象的状态信息,通常由网络通信失败所致

二、Pod的创建过程

  • 1、用户通过kubectl或其他api客户端提交需要创建的pod信息给apiServer
  • 2、apiServer开始生成pod对象的信息,并将信息存入etcd,然后返回确认信息至客户端
  • 3、apiServer开始反映etcd中的pod对象的变化,其他组件使用watch机制来跟踪检查apiServer上的变动
  • 4、scheduler发现有新的pod对象要创建,开始为pod分配足迹并将结果更新只apiServer
  • 5、node节点上的kubectl发现有pod调度过来,尝试调用docker启动容器,并将结果回送至apiServer
  • 6、apiServer将接收到的pod状态信息存入etcd中

在这里插入图片描述

三、Pod的终止过程

  • 1、用户向apiServer发送删除pod对象的命令
  • 2、apiServer中的pod对象信心ui随着时间的退役而更新,在宽限期内(默认30秒),pod被视为dead
  • 3、将pod标记为terminating状态
  • 4、kubelet在监控到pod对象转为terminating状态的同时启动pod关闭过程
  • 5、端点控制器监控到pod对象的关闭行为时将其从所有匹配到此端点的service资源的端点列表中移除
  • 6、如果当前pod对象定义了preStop钩子处理器,则在其标记为terminating后即会以同步的方式启动执行
  • 7、pod对象的容器进程收到停止信号
  • 8、宽限期结束后,若pod中还存在仍在运行的进程,那么pod对象会收到吉利终止的信号
  • 9、kubelet请求apiServer将此pod资源的款限制设置为0从而完成删除操作,此时pod对于用户已不可见
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

redrose2100

您的鼓励是我最大的创作动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值