1.健康检测
exec探测
apiVersion: v1
kind: Pod
metadata:
name: liveness-exec
spec:
containers:
- name: liveness-demo
image: busybox
args:
#容器初始化执行的命令
- /bin/sh
- -c
- touch /tmp/healthy; sleep 10; rm -rf /tmp/healthy; sleep 600
#表示,容器一运行就创建一个文件,睡上10s,再删除这个文件
livenessProbe:
#健康检测
exec:
#ExecAction,在容器中执行特定的命令,命令退出返回0表示成功
#TCPSocketAction,根据容器IP地址及特定的端口进行TCP检查,端口开放表示成功
#HTTPGetAction,根据容器IP、端口及访问路径发起一次HTTP请求,如果返回码在200到400之间表示>成功
command:
- cat
- /tmp/healthy
#这里用exec探测,不停探测"/tmp/healthy"是否存在,不在了就重启
http 探测
apiVersion: v1
kind: Pod
metadata:
name: liveness-http
spec:
containers:
- name: liveness-http
image: nginx
livenessProbe:
httpGet:
path: /index.html
#探测路径
port: 80
scheme: HTTP
initialDelaySeconds: 20
#表示容器启动20s在,进行第一次探测 默认0s
periodSeconds: 3
#表示各3s探测一次 默认10s
timeoutSeconds: 1
#表示探测超时时间 默认1s
successThreshold: 1
#表示重失败到正常状态,要连续探测1次成功就标记为正常状态 默认1次
failureThreshold: 5
#表示重正常到失败状态,要连续探测5次失败就标记为失败状态 默认3次
[root@localhost ~]# kubectl exec liveness-http -it -- /bin/bash
#登录进容器
root@liveness-http:/# rm /usr/share/nginx/html/index.html
#手动删除index.html文件完成手动触发
kubectl describe pod liveness-exec |grep Liveness:
#运行命令查看探测状态信息
httpGet的属性
host:主机名或IP
scheme:链接类型,HTTP或HTTPS,默认为HTTP
path:请求路径
httpHeaders:自定义请求头
port:请求端口
TCP探测
apiVersion: v1
kind: Pod
metadata:
name: liveness-tcp
spec:
containers:
- name: liveness-tcp
image: nginx
livenessProbe:
tcpSocket:
port: 80
2.就绪状态探测—exec
apiVersion: v1
kind: Pod
metadata:
name: readiness-exec
spec:
containers:
- name: readiness-exec
image: nginx
args: ["/bin/sh", "-c", "while true; do touch /tmp/ready; sleep 10; rm -f /tmp/ready; sleep 10; done;"]
#表示创建个文件暂停10s,删除文件暂停10s,无限循环
readinessProbe:
#就绪状态监测
exec:
command: ["cat", "/tmp/ready"]
initialDelaySeconds: 5
periodSeconds: 1
#该容器每10s会在正常和非正常状态来回跳转
readiness配置方式和liveness类似,其他探测只要修改livenessProbe改为readinessProbe即可
3.重启策略
状态值 描述
Pending API Server已经创建该Pod,但在无法可用node能调度或Pod内还有一个或多个容器的镜像没有创建,包括正在下载镜像的过程。
Runnung Pod内所有容器均已创建,且至少有一个容器处于运行状态、正在启动状态或正在重启状态。
Succeeded Pod内所有容器均成功执行后退出,且不会再重启。
Failed Pod内所有容器均已退出,但至少有一个容器退出为失败状态。
Unknown 由于某种原因无法获取该Pod的状态,可能由于网络通信不畅导致。
apiVersion: v1
kind: Pod
metadata:
name: liveness-exec
spec:
restartPolicy: Never
#Always: 当容器失效时, 由kubelet自动重启该容器,正常退出也重启
#OnFailure: 当容器终止运行且退出码不为0时, 由kubelet自动重启该容器,正常退出不重启
#Never: 不论容器运行状态如何, kubelet都不会重启该容器,无论是否正常退出,都不重启
containers:
- name: liveness-exec
image: busybox
args:
- /bin/sh
- -c
- touch /tmp/healthy; sleep 10; rm -rf /tmp/healthy; sleep 600
livenessProbe:
exec:
command:
- cat
- /tmp/healthy