Kubernetes学习笔记(三) —— POD生命周期与重启、拉取策略
Kubernetes 中, pod 从创建到成功运行会分别处于不同的阶段,每个阶段又分为不同的状态,本文将简单介绍这个环节
在 K8S 源码中,使用了 PodPhase 这个变量定义这几个阶段信息,如下图所示:
K8S中Pod生命周期
- 运行中(Running):该 Pod 已经绑定到了一个节点上,Pod 中所有的容器都已被创建。至少有一个容器正在运行,或者正处于启动或重启状态。
- 等待中(Pending): 创建 Pod 的请求已被 Kubernetes 系统接受,但有一个或者多个容器镜像尚未创建。可能的原因有,写数据到etcd,调度,pull镜像,启动容器这四个阶段中的任何一个阶段,pending 伴随的事件通常会有:ADDED, Modified这两个事件的产生。等待时间包括调度 Pod 的时间和下载镜像的时间,这可能需要花些时间。
- 正常终止(Succeeded):pod中的所有的容器已经正常的自行退出,并且k8s永远不会自动重启这些容器,一般会是在部署job的时候会出现。
- 异常停止(Failed):Pod 中的所有容器都已终止了,并且至少有一个容器是因为失败终止。也就是说,容器以非0状态退出或者被系统终止。
- 未知状态(PodUnkonwn):出于某种原因,无法获得Pod的状态,通常是由于与Pod主机通信时出错。
Pod 的详细状态
- CrashLoopBackOff: 容器退出,kubelet正在将它重启,建议增加内存、CPU等资源
- InvalidImageName: 无法解析镜像名称
- ImageInspectError: 无法校验镜像
- ErrImageNeverPull: 策略禁止拉取镜像
- ImagePullBackOff: 正在重试拉取,建议更换镜像仓库
- RegistryUnavailable: 连接不到镜像中心
- ErrImagePull: 通用的拉取镜像出错
- CreateContainerConfigError: 不能创建kubelet使用的容器配置
- CreateContainerError: 创建容器失败
- m.internalLifecycle.PreStartContainer 执行hook报错
- RunContainerError: 启动容器失败
- PostStartHookError: 执行hook报错
- ContainersNotInitialized: 容器没有初始化完毕
- ContainersNotReady: 容器没有准备完毕
- ContainerCreating:容器创建中,长时间卡死要decribe与logs查看日志分析内容
- PodInitializing:pod 初始化中
- DockerDaemonNotReady:docker还没有完全启动
- NetworkPluginNotReady: 网络插件还没有完全启动
POD重启策略
pod的重启策略有3种,如下:
- Always:容器失效时,自动重启该容器,这是默认值
- OnFailure:容器停止运行且退出码不为0时重启
- Never:不论状态为何,都不重启该容器
重启策略适用于pod对象中的所有容器,首次需要重启的容器,将在其需要时立即进行重启,随后再次需要重启的操作将由kubelet延迟一段时间后进行,且反复的重启操作的延迟时长为10s,20s,40s,80s,160s,300s,300s是最大延迟时长
mkdir /etc/k8s
cat > /etc/k8s/nginx-pod.yaml <<-'EOF'
apiVersion: v1
kind: Pod
metadata:
name: pod-nginx
spec:
containers:
- name: container-nginx
image: nginx:latest
ports:
- containerPort: 80
#定义重启策略
restartPolicy: Never
EOF
POD镜像拉取策略
- IfNotPresent:默认值,镜像在宿主机上不存在时才拉取(面对稳定版本)
- Always:每次创建 Pod 都会重新拉取一次镜像(面对不断变更版本)
- Never: Pod 永远不会主动拉取这个镜像
mkdir /etc/k8s
cat > /etc/k8s/nginx-pod.yaml <<-'EOF'
apiVersion: v1
kind: Pod
metadata:
name: pod-nginx
spec:
containers:
- name: container-nginx
image: nginx:latest
#镜像拉取策略
imagePullPolicy: IfNotPresent
ports:
- containerPort: 80
restartPolicy: Never
EOF