如何使用 Kubectl 优雅的滚动更新应用

系统 Linux
Kubernetes 中的 Pod 通常应该是 "Running" 状态,然而有时候我们需要针对正在运行的 Pod 调度到其它的节点或是基于其它特殊的原因,将正常运行的 Pod 进行重启。

Pod 的重启方式也有不少,比如常见删除正在运行的 Pod 让其创建新的 Pod 实例(单个 Pod 无法直接使用该方式)。以下罗列出几种常见的方式仅供备忘:

方法1:滚动重启方法[推荐]

自 Kubernetes 1.15 版本就开始支持滚动重启部署。这是 Kubernetes 中最快的重启机制,因为它是新增的。下面给出的命令会一个一个地关闭并重新启动部署中的每个 Pod。

$ kubectl rollout restart deployment nginx-deploy
  • 提示:由于大多数容器仍在运行,因此整个过程是纵享丝滑--无感知的。

方法2:环境变量方法

这种方式就是给运行的容器分配一个新的环境变量,来强制 Pod 重新启动。例如: 增加一个容器部署日期(实际可能未使用到该变量)

$ kubectl set env deployment nginx-deploy DEPLOY_DATE="$(date)"
  • 提示:在上面的场景中,使用了set env 修改了环境变量,deployment [deployment name] 选择了你的 deployment,DEPLOY DATE="$(date)" 修改了deployment date 并导致pod 更新。这种方式也是无感知的。

方法3:副本扩/缩容

当副本数量设置为 0 时,Kubernetes 会消除它不再需要的副本。设置大于 0 后,Kubernetes 会生成新的副本。

$ kubectl scale --replicas=0 deployment nginx-deploy
$ kubectl scale --replicas=N deployment nginx-deploy

以上方式会中断业务,我们也可以使用不中断业务的方式来重启应用。比如记录当前的 Pod 副本数量,使用 scale --replicas 命令来分配一个大于当前的副本数值的值,使用 kubectl delete pod 方式删除旧 Pod,最后将使用scale --replicas 还原成正常的副本数量。

  • 提示:不建议使用这种方式来重启应用。

结论

Kubernetes 是一个非常牛X的编排系统,然而只要是系统,就一定会出现问题。当出现问题时,可以利用上述 3 种方式快速安全地让您的应用程序恢复并运行,而不会影响用户体验。

参考引用

  • [1] https://linuxhint.com/kubectl-rollout-restart/
  • [2] https://kubernetes.io/zh/docs/reference/kubectl/cheatsheet/
责任编辑:庞桂玉 来源: 奇妙的Linux世界
相关推荐

2021-01-28 14:53:19

PHP编码开发

2017-07-26 11:32:50

NETRabbitMQ系统集成

2015-11-26 10:53:45

LinuxWindowsMac OS

2023-02-13 14:37:13

开发web浏览器

2023-06-16 09:08:39

ReactContextRFC

2022-09-14 08:16:48

装饰器模式对象

2021-03-28 09:17:18

JVM场景钩子函数

2017-12-19 10:03:44

JavaLinux代码

2021-01-18 13:17:04

鸿蒙HarmonyOSAPP

2022-10-27 11:23:26

GoFrame共享变量

2023-11-30 08:08:30

k8s优雅停机

2024-07-03 09:13:26

SwiftUI修饰符框架

2023-06-28 08:25:14

事务SQL语句

2019-11-15 09:58:04

LinuxAsciinemapython

2022-11-11 07:48:56

ORM链式轮播图

2022-11-15 07:50:47

ORM链式操作删除

2022-01-10 09:35:50

日志语言解析器

2022-02-28 09:19:12

MDK芯片软件

2020-05-14 09:15:52

设计模式SOLID 原则JS

2022-01-21 09:45:42

Mozilla SOKubernetesLinux
点赞
收藏

51CTO技术栈公众号