前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >k8s 探针 livenessProbe 和 readinessProbe 必须不一样

k8s 探针 livenessProbe 和 readinessProbe 必须不一样

原创
作者头像
sir5kong
发布2023-05-24 20:53:52
6160
发布2023-05-24 20:53:52
举报
文章被收录于专栏:企业容器化之路
  • livenessProbe: 存活探针
  • readinessProbe: 就绪探针

简单来说 livenessProbe 能够起到存活检测和自动重启的的效果,readinessProbe 用于管理 Pod 状态并影响 Kubernetes Service 流量分配。当 readinessProbe 检测失败,容器所在 Pod 上报未就绪状态,并且从 Service 断开流量。

代码语言:yaml
复制
## 探针版本一 (反面案例)
livenessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 10
  periodSeconds: 10
readinessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 10
  periodSeconds: 10

首先提供一个反面案例,上面版本一两种探针的参数一模一样,这是有问题的。假如 /health 不通,两种探针会同时失败,会直接触发重启,readinessProbe 起不到保护的作用。

如果把 livenessProbe.periodSeconds 检测周期调大一点,像下面版本二这样。当 Pod 过载时 /health 调不通,readinessProbe 会先失败,此时 Pod 不再负载流量可能会很快缓过来,/health 恢复后就不会触发重启。对于 7*24 小时在线的业务,这点差异很重要。

代码语言:yaml
复制
## 探针版本二
livenessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 10
  periodSeconds: 15   ## 默认值 10
readinessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 10
  periodSeconds: 10   ## 默认值 10

死亡重启问题

代码语言:yaml
复制
## 探针版本一
livenessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 10
  periodSeconds: 10
  failureThreshold: 3  ## 默认值 3

上面探针版本一如果容器启动时间大于 40 秒就会发生死亡重启。因为容器启动时探针会初始等待 10 秒,然后连续 3 次存活探针检测失败会触发重启,每次容器还没完成启动就会触发重启。

代码语言:yaml
复制
## 探针版本三
livenessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 180
  periodSeconds: 10    ## 默认值 10
  failureThreshold: 5  ## 默认值 3
readinessProbe:
  httpGet:
    path: /health
    port: 8080
    scheme: HTTP
  initialDelaySeconds: 10
  periodSeconds: 5     ## 默认值 10
  failureThreshold: 3  ## 默认值 3

上面探针版本三是再次优化过的,把存活探针 initialDelaySecondsfailureThreshold 调大,就绪探针 periodSeconds 调小了。这样的配置适合启动比较慢的容器,比如启动时间在 1-2 分钟。

另外 startupProbe 也可以解决死亡重启问题,配合存活探针会更得心应手。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 死亡重启问题
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档