【赵渝强老师】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
相关推荐
金刚猿5 小时前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
JH_Kong6 小时前
解决 WSL 中 Docker 权限问题:从踩坑到完整修复
docker·容器
陈桴浮海7 小时前
Kustomize实战:从0到1实现K8s多环境配置管理与资源部署
云原生·容器·kubernetes
张小凡vip8 小时前
Kubernetes--k8s中部署redis数据库服务
redis·kubernetes
Hello.Reader9 小时前
Flink Kubernetes HA(高可用)实战原理、前置条件、配置项与数据保留机制
贪心算法·flink·kubernetes
ShiLiu_mtx10 小时前
k8s - 7
云原生·容器·kubernetes
MonkeyKing_sunyuhua13 小时前
docker compose up -d --build 完全使用新代码打包的方法
docker·容器·eureka
醇氧14 小时前
【docker】mysql 8 的健康检查(Health Check)
mysql·docker·容器
匀泪17 小时前
云原生(LVS NAT模式集群实验)
服务器·云原生·lvs
70asunflower17 小时前
用Docker创建不同的容器类型
运维·docker·容器