本篇文章为大家展示了kubernetes容器健康检测以及就绪检测的过程是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
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"是否存在,不在了就重启
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:请求端口
apiVersion: v1 kind: Pod metadata: name: liveness-tcp spec: containers: - name: liveness-tcp image: nginx livenessProbe: tcpSocket: port: 80
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即可
状态值 描述 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
上述内容就是kubernetes容器健康检测以及就绪检测的过程是怎样的,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。