【赵渝强老师】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 小时前
服务网格安全(Istio):用零信任架构重构微服务通信安全
网络安全·微服务·云原生·系统安全·安全架构
Super_man541886 小时前
docker-compose-语法使用安装说明
运维·docker·容器
自己的九又四分之三站台6 小时前
Docker容器常用命令汇总
运维·docker·容器
TracyCoder1239 小时前
APISIX 简介:云原生 API 网关的架构与实践
云原生·架构·apisix
鸥梨菌Honevid11 小时前
软件架构的发展历程——从早期的单体架构到如今的云原生与智能架构
云原生·架构
编码如写诗12 小时前
【国产化-k8s】超混合架构-x86+arm64+欧拉+麒麟V10部署k8s1.32+kubesphere4.1
容器·架构·kubernetes
明月看潮生15 小时前
青少年编程与数学 01-011 系统软件简介 24 Kubernetes 容器编排系统
青少年编程·容器·kubernetes·系统软件·编程与数学
珊珊而川16 小时前
uvicorn api:app --host 0.0.0.0 --port 7777容器运行失败
容器
Fireworkitte16 小时前
Docker 日志
docker·容器·eureka