k8s 探针

Kubernetes 中的探针(Probes)用于检测容器的健康状态或就绪状态,确保应用在运行时的可靠性。Kubernetes 提供三种探针类型,它们的核心区别在于用途失败后的处理逻辑。以下是它们的详细说明和对比:

1. 启动探针(Startup Probe)

  • 用途
    检测容器是否成功启动

    • 适用于启动时间较长的应用(如 Java 服务、复杂初始化逻辑的应用)。
    • 防止存活探针(Liveness Probe)在应用启动完成前误判容器为不健康。
  • 关键行为

    • 仅在容器启动阶段运行,成功后不再执行
    • 如果失败,容器会被重启(类似 Liveness Probe)。
  • 典型场景

startupProbe:
  httpGet:
    path: /health
    port: 8080
  failureThreshold: 30   # 允许最多 30 次探测失败
  periodSeconds: 5       # 每 5 秒探测一次

2. 存活探针(Liveness Probe)

  • 用途
    检测容器是否仍在正常运行

    • 如果探针失败,Kubernetes 会重启容器(通过 kubelet)。
    • 用于处理运行时死锁、内存泄漏等问题。
  • 关键行为

    • 在容器整个生命周期中周期性执行
    • 失败后触发容器重启(可能伴随 Pod 重新调度)。
  • 典型场景

    livenessProbe:
    httpGet:
      path: /health
      port: 8080
    periodSeconds: 10
    

3. 就绪探针(Readiness Probe)

  • 用途
    检测容器是否已准备好接收流量

    • 如果探针失败,Kubernetes 会从 Service 的 Endpoints 中移除该 Pod,停止向其发送请求。
    • 用于等待依赖项(如数据库连接、缓存初始化)完成后再接收流量。
  • 关键行为

    • 在容器整个生命周期中周期性执行
    • 失败后不会重启容器,仅停止流量转发。
  • 典型场景

    readinessProbe:
      tcpSocket:
        port: 8080
    

三者的核心差异对比

探针类型设计目的执行阶段失败后果适用场景
Startup确保容器成功启动仅在启动阶段运行一次重启容器启动耗时的应用
Liveness检测容器是否存活启动后周期性执行重启容器处理运行时崩溃或僵死
Readiness检测容器是否准备好接收流量启动后周期性执行从 Service 移除流量转发依赖项未就绪时暂停服务流量

协作关系

  • 启动探针 的优先级最高:
    它确保在容器启动期间,存活探针和就绪探针不会生效(直到 StartupProbe 成功)。
  • 存活探针就绪探针并行运行:
    • 存活探针负责修复不健康的容器。
    • 就绪探针负责流量控制。
Kubernetes 中,探针(Probes)用于监控容器的健康状态并据此做出相应的管理决策。Kubernetes 提供了三种类型的探针:**Liveness Probe**(存活探针)、**Readiness Probe**(就绪探针),以及 **Startup Probe**(启动探针)。每种探针都有其特定的作用和应用场景。 ### 1. Liveness Probe (存活探针) 存活探针的主要目的是判断容器是否处于“存活”状态。如果存活探针失败多次,Kubernetes 认为容器已经失效并将对其进行重启操作。这有助于自动恢复因程序崩溃或其他原因导致的服务中断。 #### 示例配置: ```yaml livenessProbe: httpGet: path: /healthz port: 8080 initialDelaySeconds: 30 # 容器启动后的初始延迟时间(秒) periodSeconds: 10 # 检查间隔时间(秒) timeoutSeconds: 1 # 超时时长(秒) failureThreshold: 3 # 连续失败次数阈值,默认是3次连续失败才认为挂掉 ``` 在这个例子中,每隔 10 秒向 `/healthz` 发送一次 HTTP 请求来检查服务是否正常工作。若三次请求均未成功,则判定容器异常进而触发重启流程。 ### 2. Readiness Probe (就绪探针) 就绪探针用来确定 Pod 是否已准备好处理外部流量和服务请求。即使一个容器还在初始化过程中,只要它的就绪探针返回成功信号,就会被视为准备完毕,并将其 IP 地址加入 Service 的端点列表中参与调度分发任务。 #### 示例配置: ```yaml readinessProbe: tcpSocket: port: 9999 # TCP连接测试目标端口 initialDelaySeconds: 5 periodSeconds: 10 timeoutSeconds: 1 successThreshold: 1 # 成功几次之后才算真正的Ready ``` 此段落表示每当新实例上线初期等待五秒钟再开始检测,以后每隔十秒尝试建立与本地 `9999` 端口号之间的TCP连接验证它能否顺利到达;只有首次尝试即成功的状况才会被认为完全可用。 ### 3. Startup Probe (启动探针) *(仅适用于 v1.16+)* 对于某些需要长时间才能完成初始化的应用来说,单独依靠 liveness probe 可能不足以准确反映实际状况,因为后者通常会在应用部分功能尚未全部加载前就已经开始了监测过程。而 startup probes 则专门为这种情况设计——它们会一直等到应用程序真正进入稳定阶段后停止活动,随后将控制权交给常规的 liveness 和 readiness checks. #### 示例配置: ```yaml startupProbe: exec: command: ["ls", "/tmp"] failureThreshold: 30 # 允许的最大连续失败次数 periodSeconds: 10 timeoutSeconds: 1 ``` 这意味着每次执行命令 `ls /tmp`, 如果在指定时间内未能得到预期结果则计作一次错误记录直至累计到设定限度为止。 ### 探针类型及其实现方式 每个探针对应多种实现手段: - **HTTP Get:** 向给定路径发起 GET 请求; - **Exec Command:** 在容器内运行一条 shell 命令; - **TCP Socket:** 尝试创建一个到某个地址/端口组合上的套接字连接。 以上就是关于 K8S探针的基本概念、用途及其常用配置示例,希望对您有所帮助! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值