K8s Pod 优雅关闭:如何避免对生产环境造成影响

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

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

187b5eb8632cf2707434682508408891.jpeg

但这还不够!

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

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

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

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

2d74ad3eac19f72727b28ce83d9428e9.jpeg

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

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

e95259903563890adb5071f8940f3b0c.jpeg

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

那么你能做什么呢?

等待!

c8c8ec828655a4b6d3b278ce622999c2.jpeg

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

那么应该如何等待呢?

b48ea75d2c22b4b3dcaf841c8216ca95.jpeg

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

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

  • 发送 SIGTERM 信号。

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

89cdb309a127f54582a91319ac80ddb0.jpeg

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

0c682ee22359bb21efc13ca422e1f1d3.jpeg

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

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

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

5eb2c937328f1c74c3e870ddc739f297.jpeg

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

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

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

edd6159b5abc7810de08a0067ed14d8c.jpeg - END -

往期回顾

◆ 如何使用OpenTelemetry进行端对端跟踪

◆ 云原生数据系统的设计思考

◆ 作业帮多云多活架构的探索和实践

◆ 分布式系统关键技术:全栈监控

◆ 高性能负载均衡-分类和算法

◆ 得物 App 全栈可观测平台落地实践

◆ 解决微服务之间的数据依赖问题

7eba99e664fef43f4ebc767c953cd8c7.png

技术交流,请加微信: jiagou6688 ,备注:Java,拉你进架构群

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值