【赵渝强老师】K8s中Pod探针的ExecAction

在K8s集群中,当Pod处于运行状态时,kubelet通过使用探针(Probe)对容器的健康状态执行检查和诊断。K8s支持三种不同类型的探针,分别是:livenessProbe(存活探针)、readinessProbe(就绪探针)和startupProbe(启动探针)。不同类型的探针都支持三种方式检查方法,分别是:HTTPGetAction、ExecAction和TCPSocketAction。

视频讲解如下
【赵渝强老师】K8s Pod探针的ExecAction

下面重点讨论提下探针的ExecAction检查方法。该检查方法是在容器内部执行Shell命令,如果命令退出时返回码为0则认为诊断成功。下面通过一个具体的示例来演示如何使用"ExecAction"方式的探针。

(1)创建execaction.yaml文件,输入下面的内容。

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  labels:
    test: liveness
  name: liveness-exec
spec:
  containers:
  - name: liveness
    image: busybox
    args:
    - /bin/sh
    - -c
    - touch /tmp/healthy; sleep 10; rm -rf /tmp/healthy; sleep 10
    ## 这里以存活探针为例
    livenessProbe:  
       ## 指定存活探针检查方法是ExecAction
      exec:
         ## 指定在容器内具体执行的命令
        command:
        - cat
        - /tmp/healthy
       ## 指定容器启动5秒后才进行检查
      initialDelaySeconds: 5   
       ## 指定每隔5秒检查一次
      periodSeconds: 5  

提示:这里使用ExecAction检测文件"/tmp/healthy"。该文件创建后,每隔10秒就会被删除。如果通过执行ExecAction检测文件被删除,存活探针就会返回失败,然后根据重启策略进行Pod的重启。下次ExecAction检测时再重复这一过程,检测的过程将无限循环。

(2)使用"kubeclt apply"命令应用execaction.yaml文件。

powershell 复制代码
kubectl apply -f execaction.yaml 

(3)多执行几次命令查看Pod的状态信息,如下图所示。

powershell 复制代码
kubectl get pod
相关推荐
Lin_Aries_04212 小时前
基于 CI/CD 平台将应用程序自动部署到 Kubernetes 集群
运维·ci/cd·docker·云原生·容器·kubernetes·jenkins
Tadas-Gao4 小时前
微服务可观测性的“1-3-5”理想:从理论到实践的故障恢复体系
java·开发语言·微服务·云原生·架构·系统架构·可观测
神秘人X7077 小时前
Docker 镜像结构详解
运维·docker·容器
编码追梦人15 小时前
探索 Docker/K8s 部署 MySQL 的创新实践与优化技巧
mysql·docker·kubernetes
fire-flyer16 小时前
docker 跨架构兼容
docker·容器
缘的猿17 小时前
Kubernetes 中 ETCD 数据备份与恢复完整指南
容器·kubernetes·etcd
bestcxx17 小时前
(二十七)、k8s 部署前端项目
前端·容器·kubernetes
白白白白熊爱吃麦当劳17 小时前
k8s知识点总结5
docker·容器·kubernetes
K_i13420 小时前
Kubernetes HTTPS迁移:Ingress到GatewayAPI实战
容器·https·kubernetes
Vahala0623-孔勇1 天前
微服务网关深度设计:从Spring Cloud Gateway到Envoy,流量治理与安全认证实战指南
java·安全·微服务·云原生