【赵渝强老师】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
相关推荐
星之尘10211 小时前
“粽”览全局:分布式系统架构与实践深度解析(端午特别版)
分布式·spring cloud·微服务·系统架构·kubernetes·serverless·可用性测试
三金C_C1 小时前
docker 部署 gin
docker·容器·gin
小峰编程2 小时前
rsync服务的搭建
linux·运维·服务器·云原生·centos·服务搭建
长勺2 小时前
docker常见考点
docker·容器
迢迢星万里灬3 小时前
Java求职者面试指南:DevOps技术栈深度解析
java·ci/cd·docker·kubernetes·jenkins·devops
玩电脑的辣条哥5 小时前
如何用docker部署ELK?
elk·docker·容器
Chuncheng's blog6 小时前
CentOS 7 安装docker缺少slirp4netnsy依赖解决方案
运维·docker·容器
数据智能老司机9 小时前
理解 Argo CD
git·kubernetes·自动化运维
!chen9 小时前
鲲鹏Arm+麒麟V10 K8s 离线部署教程
java·arm开发·kubernetes
David爱编程9 小时前
从 0 到 1 快速掌握 Docker 基本操作
后端·docker·容器