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

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

下面重点讨论提下探针的TCPSocketAction检查方法。该检查方法是对指定容器的IP地址和端口发起建立TCP Socket的请求。如果Socket连接被成功建立,则诊断被认为是成功的。

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

下面通过一个具体的示例来演示如何使用"TCPSocketAction"方式的探针。

yaml 复制代码
(1)创建tcpsocketaction.yaml文件,输入下面的内容。
apiVersion: v1
kind: Pod
metadata:
  name: liveness-tcp
  labels:
    app: httpd
spec:
  containers:
  - name: liveness-tcp
    image: nginx
    ports:
    - containerPort: 80
    readinessProbe:
      tcpSocket:
        port: 8080
      initialDelaySeconds: 10
      periodSeconds: 5
    livenessProbe:
      tcpSocket:
        port: 8080
      initialDelaySeconds: 10
      periodSeconds: 5

提示:tcpsocketaction.yaml文件创建了一个Pod,并基于Nginx的镜像创建了容器。Nginx提供的服务端口是80。然后配置了两个探针分别是readinessProbe和livenessProbe。这两个探针通过使用TCPSocketAction的方式连接端口8080端口。第一次监测时间为Pod容器启动后的10秒,以后后每隔5秒监测一次。由于探针无法连接容器的8080端口而导致检测失败,所以容器一直重启。

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

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

(3)使用命令"kubectl describe"查看Pod的信息,如下图所示。

powershell 复制代码
kubectl describe pod/liveness-tcp
相关推荐
MonkeyKing_sunyuhua1 小时前
docker compose up -d --build 完全使用新代码打包的方法
docker·容器·eureka
醇氧2 小时前
【docker】mysql 8 的健康检查(Health Check)
mysql·docker·容器
匀泪5 小时前
云原生(LVS NAT模式集群实验)
服务器·云原生·lvs
70asunflower6 小时前
用Docker创建不同的容器类型
运维·docker·容器
CodeGolang6 小时前
Docker容器化部署Zabbix监控系统完整指南
docker·容器·zabbix
DolitD6 小时前
云流技术深度剖析:国内云渲染主流技术与开源和海外厂商技术实测对比
功能测试·云原生·开源·云计算·实时云渲染
ghostwritten8 小时前
春节前夕,运维的「年关」:用 Kubeowler 给集群做一次「年终体检」
运维·云原生·kubernetes
[shenhonglei]17 小时前
灰度发布功能需求说明书
kubernetes
lpruoyu17 小时前
【Docker进阶-03】存储原理
docker·容器
文静小土豆18 小时前
Docker 与 containerd 代理配置详解:镜像拉取速度慢的终极解决方案
运维·docker·容器