在 Pod 的 YAML 清单的 spec 中包含一个 restartPolicy 字段,其可能取值包括
默认值是 Always。
restartPolicy 适用于 Pod 中的所有容器。restartPolicy 仅针对同一节点上 kubelet 的容器重启动作。当 Pod 中的容器退出时,kubelet 会按指数回退方式计算重启的延迟(10s、20s、40s、…),其最长延迟为 5 分钟。 一旦某容器执行了 10 分钟并且没有出现问题,kubelet 对该容器的重启回退计时器执行重置操作。
编辑 pod-restartPolicy.yaml,内容如下所示
apiVersion: v1
kind: Pod
metadata:creationTimestamp: nulllabels:run: pod-restartmyname: pod-restartname: pod-restart
spec:containers:- image: nginximagePullPolicy: IfNotPresentcommand: ["sh","-c","sleep 10"]name: pod-restartresources: {}dnsPolicy: ClusterFirstrestartPolicy: Always #将重启策略定义为:Always
status: {}
创建 pod-restartPolicy,并查看其状态
kubectl apply -f pod-restartPolicy.yaml
kubectl get pod -w

可以看到当容器执行完 sleep 10 命令后,会显示完成(Completed),因为重启策略,该Pod会反复重启执行 sleep 10 命令。
完成上述操作后请删除该 Pod。
编辑 pod-OnFailure.yaml,内容如下所示
apiVersion: v1
kind: Pod
metadata:creationTimestamp: nulllabels:run: pod-onfailuremyname: pod-OnFailurename: pod-onfailure
spec:containers:- image: nginximagePullPolicy: IfNotPresentcommand: ["sh","-c","sleep 10"]name: pod-onfailureresources: {}dnsPolicy: ClusterFirstrestartPolicy: OnFailure #将重启策略定义为:OnFailure
status: {}
创建 pod-OnFailure,并查看其状态
kubectl apply -f pod-OnFailure.yaml
kubectl get pod -w
该状态是sleep 10命令执行完成,并不是 Pod 启动失败,所以会一直保持completed状态。

如果将command中的参数改为"sh","-c","sleep 10 ; XXXX",Pod会反复重启,因为xxxx是一条无效命令。

完成上述操作后请删除该 Pod。
编辑 pod-nerver.yaml,内容如下所示
apiVersion: v1
kind: Pod
metadata:creationTimestamp: nulllabels:run: pod-nervermyname: pod-nervername: pod-nerver
spec:containers:- image: nginximagePullPolicy: IfNotPresentcommand: ["sh","-c","XXXX"] #将命令修改为无效命令来查看 Never 策略。name: pod-nerverresources: {}dnsPolicy: ClusterFirstrestartPolicy: Never #将重启策略定义为:Never
status: {}
即使sleep 10 ; XXXX命令执行失败,Pod 也不会重启,一直停留在 error 状态。

完成上述操作后请删除该 Pod。
上一篇:【SpringMVC 入门教程】
下一篇:vue 前后端分离下载文件