K8s进阶之路-Pod的生命周期

Pod创建过程:
  • 首先创建一个pod,然后创建一个API Server 和 Etcd【把创建出来的信息存储在etcd中】
  • 然后创建 Scheduler,监控API Server是否有新的Pod,如果有的话,会通过调度算法,把pod调度某个node上
  • 在node节点,会通过 kubelet -- apiserver 读取etcd 拿到分配在当前node节点上的pod,然后通过docker创建容器

在容器环境初始化后:
初始化阶段:

  1. 初始化容器(由0到多个 )
  2. start启动:钩子函数(回调函数)

配置Poststart:利用钩子函数实现
Lifecycle生命周期探针:
注:钩子函数分为:
start 启动:poststart (容器启动后钩子): 如容器启动后需要执行一些初始化命令就需要用到PostStart钩子
stop结束:prystop 容器终止前钩子 : 如容器被干掉之前需要执行一些操作,如java服务在容器终止前打印堆栈信息,帮助开发排查异常原因)
开始与结束中间就是容器)
3.启动探针: Startup Probe检测主容器是否启动
4.就绪探针: ReadnessProbe启动成功后的探测
5.存活探针: LivenessProbe持续检测应用是否存活

Prestop生命周期
利用prestop数据清理:




#kubectl get po -o -wide 获取详细信息
通过curl查看访问地址是否执行

测试删除:
#vim nginx-prestop-po.yaml
#kubectl get po -w
-w:持续监听
#time kubectl delete po nginx-po
-time:会监听命令执行的时间
#vim nginx-prestop-po.yaml
默认是30

相关推荐
Zsr1023几秒前
POD控制器:集群的“自动化运维管家”
docker·容器·kubernetes
汪碧康4 分钟前
一文掌握k8s容器的资源限制
docker·云原生·容器·golang·kubernetes·k8s·xkube
可爱又迷人的反派角色“yang”7 分钟前
k8s(七)
java·linux·运维·docker·云原生·容器·kubernetes
optimistic_chen7 分钟前
【Docker入门】namespace 空间隔离
linux·运维·docker·容器·空间隔离
骇客野人8 分钟前
Linux通过自动脚本自动化推送k8s Docker镜像
linux·kubernetes·自动化
Java程序员威哥11 分钟前
Spring Boot 3.x 云原生终极适配:GraalVM 原生镜像构建 + Serverless 生产级部署(完整实战+最优模板)
java·开发语言·spring boot·后端·云原生·serverless·maven
萧曵 丶12 分钟前
Kubernetes(k8s)搭建指南
云原生·容器·kubernetes
周壮10 小时前
01 一探究竟:从架构的演变看微服务化架构
微服务·云原生·架构
周壮11 小时前
04 服务治理:Nacos 如何实现微服务服务治理
微服务·云原生·架构
雨落秋垣11 小时前
简单的在宝塔面板的Docker环境中为网站同时启用IPv6支持
云原生·eureka