繁体   English   中英

k8s liveness probe失败时发送给容器中运行的进程的信号是什么? 杀死或终止

[英]What is the signal sent to the process running in the container when k8s liveness probe fails? KILL or TERM

我有一个用例可以优雅地终止容器,其中我有一个脚本可以使用命令“kill PID”从容器内优雅地终止进程。(这将发送 TERM 信号)但我也配置了活性探针。 当前活性探针配置为以 60 秒的间隔进行探测。 因此,如果在发送正常终止信号后不久进行活性探测,则当终止仍在进行中时,容器的整体健康状况可能会变得至关重要。 在这种情况下,活性探测将失败,容器将立即终止。

所以我想知道 kubelet 是用 TERM 还是 KILL 来杀死容器。

感谢您的支持 在此先感谢

在 Kubernetes 中,Liveness Probe 检查容器的健康状态。

要回答关于它是使用 SIGKILL 还是 SIGTERM 的问题,答案是按顺序使用两者。 这就是幕后发生的事情。

  1. 活性探针检查失败
  2. Kubernetes 停止将流量路由到容器
  3. Kubernetes 重启容器
  4. Kubernetes 再次开始将流量路由到容器

对于容器重启,首先发送 SIGTERM 并等待参数化的宽限期,然后 Kubernetes 发送 SIGKILL。

解决您的问题的一个技巧是使用该属性:

timeoutSeconds

这指定了请求在被视为失败之前需要多长时间才能做出响应。 如果您的应用程序上线所需的时间是可预测的,您可以添加和调整此参数。

此外,您可以在livenessProbe之前使用readinessProbe ,并有足够的延迟让容器在重新启动进程后投入使用。 检查https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-probes/以获取有关使用哪些参数的更多详细信息。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM