如何优雅的关闭 Kubernetes 中运行的 Pod

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

0167aa98e1387f1771834416ec68fb4b.jpeg

当我们使用命令 kubectl delete pod,Pod 就会被删除,端点控制器会从服务和 etcd 中移除其 IP 地址和端口(端点)。

你可以使用 kubectl describe service 命令来观察这个过程。

3d8f6942895661c13586f9f7cbe450ad.jpeg

但这还不够!

有几个组件同步本地的端点列表:

  • kube-proxy 保留了一个本地的端点列表,用于编写 iptables 规则。

  • CoreDNS 使用端点来重新配置 DNS 条目。

对于 Ingress 控制器、Istio 等也是如此。

2b09d8139d0a349f54409017e2fd26c6.jpeg

所有这些组件都会(最终)移除之前的端点,以便再也没有流量可以到达它。同时,kubelet 也会被通知更改并删除 Pod。

那么,当 kubelet 在其他组件之前删除 Pod 时会发生什么呢?

a4c9d4ee25e8a0e665f9c0b7c2ee31dc.jpeg

不幸的是,你会经历停机时间,因为像 kube-proxy、CoreDNS、ingress 控制器等组件仍然使用该 IP 地址来路由流量。

那么你能做什么呢?

等待!

91759ec19f7c5512d4c77010611e06ad.jpeg

如果你在删除 Pod 之前等待足够长的时间,正在进行的流量仍然可以处理的,新的流量可以被分配给其他 Pods。

那么应该如何等待呢?

94c866cc860624ad97aad41d7b3c7481.jpeg

当 kubelet 删除一个 Pod 时,它会经历以下步骤:

  • 触发 preStop 钩子(如果有的话)。

  • 发送 SIGTERM 信号。

  • 发送 SIGKILL 信号(30 秒后)。

a180ae797add3a6630ab7a0a65a64576.jpeg

你可以使用 preStop 钩子来插入人为的延迟。

c394bff207919db91aa8079a897466dd.jpeg

你可以在你的应用程序中监听 SIGTERM 信号并等待。

此外,你可以在等待结束时优雅地停止进程并退出。

Kubernetes 会给你 30 秒来做这件事(可配置),如下代码所示:

4a65aa00f9bb87c3bf35a87f6f0eea3e.jpeg

那么你应该等待 10 秒、20 秒还是 30 秒呢?

事实上这并没有统一的答案。

虽然传播端点可能只需要几秒钟,但 Kubernetes 并不保证任何时间,也不保证所有组件都会在同一时间完成。

bf4cca38ad9bdb5cb2b1e32dcb164183.jpeg

如果想了解更多相关信息,可以参考下面的一些链接:

  • https://learnk8s.io/graceful-shutdown

  • https://freecontent.manning.com/handling-client-requests-properly-with-kubernetes/

  • https://kubernetes.io/docs/concepts/workloads/pods/pod/#termination-of

  • https://medium.com/tailwinds-navigator/kubernetes-tip-how-to-gracefully-handle-pod-deletion-b28d23644ccc

  • https://medium.com/flant-com/kubernetes-graceful-shutdown-nginx-php-fpm-d5ab266963c2

  • https://www.openshift.com/blog/kubernetes-pods-life

原文链接:https://itnext.io/how-do-you-gracefully-shut-down-pods-in-kubernetes-fb19f617cd67

本文转载自:「k8s技术圈」,原文:https://url.hi-linux.com/0setm,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

b7e0f7f1358838f3e4aa59c9a566e877.gif

最近,我们建立了一个技术交流微信群。目前群里已加入了不少行业内的大神,有兴趣的同学可以加入和我们一起交流技术,在 「奇妙的 Linux 世界」 公众号直接回复 「加群」 邀请你入群。

0d26784c52ca5fed19ab561e3e3d7637.png

你可能还喜欢

点击下方图片即可阅读

c6725d7865c6515d5a09a6377292e5df.png

GitHub 星标 5.2K Star,这款利器助你轻松管理多种开发环境

c2c86294cabb09578f05802b9964c302.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

e8a8e2cef07b1f5cecb150153c9bf626.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值