K8s: 关于Kubernetes中的Pod的生命周期(状态)以及生命周期的钩子函数处理

news/2024/10/19 15:33:23/

pod 的生命周期


1 ) pod 几种常用状态

  • 1.1 )Pending(挂起)
    • Pod 已被 Kubernetes 系统接受,但有一个或者多个容器尚未创建亦未运行
    • 此阶段包括等待 Pod 被调度的时间和通过网络下载镜像的时间。
  • 1.2 )Running(运行中)
    • Pod 已经绑定到了某个节点,Pod 中所有的容器都已被创建
    • 至少有一个容器仍在运行,或者正处于启动或重启状态
  • 1.3 )Succeeded(成功)
    • Pod 中的所有容器都已成功终止,并且不会再重启
  • 1.4 )Failed(失败)
    • Pod 中的所有容器都已终止,并且至少有一个容器是因为失败终止
    • 也就是说,容器以非 0 状态退出或者被系统终止。
  • 1.5 )Unknown(未知)
    • 因为某些原因无法取得 Pod 的状态
    • 这种情况通常是因为与 Pod 所在主机通信失败

2 )pod内部的容器相应的状态

  • 一旦调度器将 Pod 分派给某个节点,kubelet 就通过容器运行时开始为 Pod 创建容器
  • 容器的状态有三种:Waiting(等待)、Running(运行中)和 Terminated(已终止)
  • $ kubectl describe pod <pod 名称>
  • 2.1 ) Creating (创建中):
    • 容器镜像正在被拉取,并且容器正在被创建
    • 这是Pod状态从Pending过渡到Running之前的一个暂态
  • 2.2 ) Running(运行中)
    • Running 状态表明容器正在执行状态并且没有问题发生
    • 如果配置了 postStart 回调,那么该回调已经执行完成
    • 如果你使用 kubectl 来查询包含 Running 状态的容器的 Pod 时
    • 你也会看到 关于容器进入 Running 状态的信息
  • 2.3 ) Terminating (终止中)
    • 容器正在被终止,这通常发生在Pod被删除或缩容时
  • 2.4 ) Terminated(已终止)
    • 处于 Terminated 状态的容器已经开始执行并且或者正常结束或者因为某些原因失败
    • 如果你使用kubectl 来查询包含 Terminated 状态的容器的 Pod 时
    • 你会看到 容器进入此状态的原因、退出代码以及容器执行期间的起止时间
  • 2.5 ) Waiting (等待)
    • 如果容器并不处在 Running 或 Terminated 状态之一,它就处在 Waiting 状态
    • 处于 Waiting 状态的容器仍在运行它完成启动所需要的操作
    • 例如,从某个容器镜像 仓库拉取容器镜像,或者向容器应用 Secret 数据等等
    • 当你使用 kubectl 来查询包含 Waiting 状态的容器的 Pod 时,你也会看到一个 Reason 字段,其中给出了容器处于等待状态的原因
  • 2.6 ) Exited(已退出)
    • 容器中的进程已经正常或异常终止,并且不再运行。这可能是由于程序执行完毕或遇到错误而退出
  • 2.7 ) Restarting (重启中)
    • 容器正在尝试重新启动,这通常是因为容器之前异常退出
    • 并且根据Pod的配置进行了自动重启

Pod 生命周期的钩子函数

  • 在Pod配置文件中,定义 postStart 和 preStop 处理函数

  • 创建一个包含一个容器的 Pod,该容器为 postStart 和 preStop 事件提供对应的处理函数

  • 创建一个 pod, 新建一个 lifecycle-demo.yaml 文件

    apiVersion: v1
    kind: Pod
    metadata:name: lifecycle-demolabels:name: lifecycle-demo
    spec:containers:- name: lifecycle-demo-containerimage: nginxlifecycle:postStart:exec:command: ["sh", "-c", "echo Hello from the postStart handler > /usr/share/message"]preStop:exec:command: ["sh","-c","nginx -s quit; while killall -0 nginx; do sleep 1; done"]resources:limits:memory: "128Mi"cpu: "500m"ports:- containerPort: 80
    
  • $ kubectl create -f lifecycle-demo.yaml

    pod/lifecycle-demo created
    
  • $ kubectl get po

    NAME             READY   STATUS              RESTARTS   AGE
    lifecycle-demo   0/1     ContainerCreating   0          8
    
  • $ kubectl exec -it lifecycle-demo -- sh 进入pod

  • $ cat /usr/share/message 查看文件是否被写入内容

    Hello from the postStart handler
    
  • 在上述配置文件中,可以看到 postStart 命令在容器的 /usr/share 目录下写入文件 message

  • 命令 preStop 负责优雅地终止 nginx 服务

  • 当因为失效而导致容器终止时,这一处理方式很有用


http://www.ppmy.cn/news/1432795.html

相关文章

小米一面:说说MVC与设计模式的关系

前言 大家好&#xff0c;我叫阿杆&#xff0c;不叫阿轩。 先来看看面试环节吧。 面试官&#xff1a;请说说MVC模式是基于哪种设计模式的&#xff1f; 求职者&#xff1a;MVC本身不就是一种设计模式吗&#xff1f; 面试官&#xff1a;我的意思是&#xff0c;MVC是基于23中设计…

算法训练 | 使用JAX训练CLIP算法_支持fine-tuning

项目应用场景 面向 CLIP 算法训练场景&#xff0c;项目采用 JAX 来实现 CLIP 算法的训练&#xff0c;支持 fine-tuning。 项目细节 > 具体参见项目 README.md (1) 安装 pip install clip-jax (2) 下载训练数据 # clone and install datacomp# download data python downl…

EPSON晶振应用到汽车电子产品上的型号有哪些?

EPSON品牌应用在汽车电子产品上的晶振.&#xff0c;当然也少不了晶振可能最熟悉的就是32.768K系列和26MHZGPS晶振用的多。 在汽车里每一个部件都应有的不一样,甚至多次使用到同一尺寸,不同频率的晶振.爱普生品牌晶振型号就有几百种,很容易混淆,要想记住汽车里所应用到的不是件…

OSPF大型实验

OSPF大型实验 实验拓扑图 实验思路 1、R4为ISP&#xff0c;其上只配置IP地址&#xff1b;R4与其他所直连设备间均使用公有IP&#xff1b; 2、R3-R5、R6、R7为MGRE环境&#xff0c;R3为中心站点&#xff1b; 3、整个OSPF环境IP基于172.16.0.0/16划分&#xff1b;除了R12有两…

顺序栈着三种结构定义及其初始化

定义 顺序堆栈这三种结构定义及其初始化 - 知乎 (zhihu.com) 根据以上链接得到&#xff1a; 1.理解为数组&#xff0c;top是这个数组的索引值&#xff1b;定义这个结构体类型时&#xff0c;系统不分配空间 在主函数声明时&#xff0c;定义了关于这个结构体的变量&#xff0c…

项目经理面试的常见问题及回答技巧

关于项目经理的面试&#xff0c;很多人都会紧张&#xff0c;那么项目经理面试会遇到哪些常见问题呢&#xff1f;应如何应对呢&#xff1f;下面的一些关于项目经理面试问题及回答技巧&#xff0c;希望能对你有所帮助。 一、自我介绍 各位面试官好&#xff0c;我叫某某&#x…

vue纯前端实现表格分页及条件查询功能

由于接口返回数据过慢&#xff0c;故而采用前端对数据进行处理分页的方法实现表格分页及条件查询。 一、表格 表格采用elementUI的el-table&#xff0c;只需要对数据data进行处理赋值即可。 <el-table:data"tableData"style"width: 100%"><el-t…

【刷题】前缀和入门

送给大家一句话&#xff1a; 既然已经做出了选择&#xff0c;最好还是先假定自己是对的。焦虑未来和后悔过去&#xff0c;只经历一个就够了。 – 张寒寺 《不正常人类症候群》 ☆ミヾ(∇≦((ヾ(≧∇≦)〃))≧∇)ノ彡☆ ☆ミヾ(∇≦((ヾ(≧∇≦)〃))≧∇)ノ彡☆ ☆ミヾ(∇≦((ヾ…