






















readinessprobe,就绪探针,是k8s中的一个概念。当 readinessprobe 检查通过,表示服务就绪,可以接受流量。当 readinessprobe 检查不通过,表示服务没有就绪,不具备提供服务流量的能力。和我们使用的consul agent的对服务的探活是类似的。
可以使用这些字段精确的控制存活和就绪检测的行为:
initialDelaySeconds:容器启动后要等待多少秒后存活和就绪探测器才被初始化,默认是 0 秒,最小值是 0。periodSeconds:执行探测的时间间隔(单位是秒)。默认是 10 秒。最小值是 1。timeoutSeconds:探测的超时后等待多少秒。默认值是 1 秒。最小值是 1。successThreshold:探测器在失败后,被视为成功的最小连续成功数。默认值是 1。 存活和启动探测的这个值必须是 1。最小值是 1。failureThreshold:当探测失败时,Kubernetes 的重试次数。 存活探测情况下的放弃就意味着重新启动容器。 就绪探测情况下的放弃 Pod 会被打上未就绪的标签。默认值是 3。最小值是 1。目前 readinessprobe 支持三种探测方式:
这三种我们建议使用http方式,更加准确反应服务的健康状态。
http 探测 demo:
readinessProbe: #健康检查方式
failureThreshold: 3 #检测失败3次表示未就绪
httpGet: #请求方式
path: /actuator/health #请求路径,此处修改为自己真实的路径,demo是java sdk 提供的接口路径
port: 8080 #请求端口,此处修改成自己真实的http监听端口
scheme: HTTP #请求协议
periodSeconds: 10 #检测间隔
successThreshold: 1 #检查成功为1次表示就绪
timeoutSeconds: 1 #监测超时时间
tcp demo:
# 此处需要填写完整的readinessProbe
# 这里是tcp 方式的readinessProbe
readinessProbe:
tcpSocket:
port: 5666 // 此处注意修改成自己真实的rpc监听端口
periodSeconds: 10
successThreshold: 1
failureThreshold: 3
对于探针的配置,有一定的最佳实践。
有以下几点:
如果配置LivenessProbe,注意设置合适的 initialDelaySeconds 值,建议180s或更长,具体根据自己业务启动情况配置。尤其java 应用。线上配置可以参考如下规则:
readinessProbe: #健康检查方式
failureThreshold: 3 #检测失败3次表示未就绪
httpGet: #请求方式
path: /actuator/health #请求路径,此处修改为自己真实的路径,demo是java sdk 提供的接口路径
port: 8080 #请求端口,此处修改成自己真实的http监听端口
scheme: HTTP #请求协议
periodSeconds: 10 #检测间隔
successThreshold: 1 #检查成功为1次表示就绪
timeoutSeconds: 1 #监测超时时间
livenessProbe:
initialDelaySeconds: 180 #健康检查方式
failureThreshold: 3 #检测失败3次表示未存活
httpGet: #请求方式
path: /actuator/health #请求路径,此处修改为自己真实的路径,demo是java sdk 提供的接口路径
port: 8080 #请求端口,此处修改成自己真实的http监听端口
scheme: HTTP #请求协议
periodSeconds: 60 #检测间隔
successThreshold: 1 #检查成功为1次表示存活
timeoutSeconds: 1 #监测超时时间
readinessprobe通过之前,在ones看到实例的状态为HealthChecking的状态,如果长时间处于HealthChecking状态,需要在pod详情中查看是否有健康检查失败的事件,通常为:Readiness probe failed: xxx
举例:
Readiness probe failed: dial tcp 192.168.158.87:8080: connect: connection refused
参考:https://kubernetes.io/zh/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。