K8s 滚动升级与回退

k8s-cert



前言

Rolling Update 即滚动更新,先更新一部分副本,成功后再继续更新更多副本,最终完成所有的副本更新。前面说到动态伸缩容并不会触发上线,仅当 Deployment Pod 模板(即 .spec.template)发生改变时才会触发上线。且上线实现了滚动特点,其好处就是无需停服的状态下即可完成服务升级,从而保证了业务的连续性。

接下来以更新 Nginx 容器镜像的版本号为例进行演示与验证。

一、升级

刚刚把副本数从 2 ——> 3,执行 kubectl apply -f nginx.yml 启动服务,可看到并没有触发上线/滚动更新:

image-20221220143311821

接着修改镜像的版本号,从 1.20.0 ——> 1.21.4

image-20221220143737833

再次启动服务,看看镜像版本是否已更新:

image-20221220144111103

看看 Pod 是否正常运行:

image-20221220144225750

小结:可看到,原来 ReplicaSet nginx-6b6cf7569 的三个 nginx:1.20.0 Pod已经被ReplicaSet nginx-7bfd89cc74的三个nginx:1.21.4 Pod替换了。

再来看看 deployment 的详情,看看具实现过程:

image-20221220144900690

其流程就是:

  • ReplicaSet nginx-7bfd89cc74 新增一个 Pod,总数为 1;
  • ReplicaSet nginx-6b6cf7569 减少一个 Pod,总数为 2(也就是说至少还有两个 Pod 是正常对外提供服务的);
  • ReplicaSet nginx-7bfd89cc74 新增一个 Pod,总数为 2;
  • ReplicaSet nginx-6b6cf7569 减少一个 Pod,总数为 2(也就是说至少还有一个 Pod 是正常对外提供服务的);
  • ReplicaSet nginx-7bfd89cc74 新增一个 Pod,总数为 3;
  • ReplicaSet nginx-6b6cf7569 减少一个 Pod,总数为 0(此时 ReplicaSet nginx-6b6cf7569 已经没有 Pod 了)。

可看到,其更新方式是以滚动的形式实现的,从而保证了业务的连续性。

二、回滚

K8s 在每次 kubectl apply 更新应用时,都会记录当前的配置,比如我原本的 Nginx 镜像为 1.20.0,那这个 1.20.0 及其其他信息都会被记录下来,其目的就是方便我们上线失败后可以回到正常的那个镜像版本。

默认情况下,K8s 只会保留近 10 个的 revision,我们可以在 Deployment 配置文件中使用 revisionHistoryLimit 字段来指定 revision 的保留数量。

kubectl edit deployment nginx

image-20221220150436717

看看可回滚的历史版本:

kubectl rollout history deployment nginx

image-20221220151203399

虽然可看到有 2、3、4 这三个可会退的版本,但是 CHANGE-CAUSE 这个字段均为 <none>,这就不太利于我们进行版本会退,想要显示CHANGE-CAUSE 值,需要在 kubectl apply 时添加 --record 参数。所以这里重新在写两个 Deployment 的 YML 文件再来启动服务。

  • nginx-a.yml

    image-20221220151707689

  • nginx-b.yml

    image-20221220151801454

分别进行 kubectl apply 更新应用:

kubectl apply -f nginx-a.yml --record
kubectl apply -f nginx-b.yml --record

image-20221220152324505

这样就能看到你是指定的哪个 YAML 文件启动的,但是这个 --record 已经被弃用了,除了这种方法之外,我们可以通过指定具体的 revision 编号来查看其详细信息,这样你就可以根据实际情况会退到具体版本,比如我们查看 revision 为 4 的版本信息。

kubectl rollout history deployment nginx --revision=4

image-20221220153002310

版本会退验证:

  • 先看看当前的 Pod 的 image 版本

    kubectl get deployment nginx -o wide
    

    image-20221220153136787

  • 比如就回到我们 revision 为 4 的版本

    kubectl rollout undo deployment nginx --to-revision=4
    

    image-20221220153805798

  • 会退完成,再次验证当前 image 镜像

    kubectl get deployment nginx -o wide
    

    image-20221220154136759

    可看到版本会退成功!

以上就是 K8s Pod 版本升级/回滚的详细流程。


  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 下面是一个简单的 k8s 滚动升级的 YAML 模板: ``` apiVersion: apps/v1 kind: Deployment metadata: name: myapp-deployment spec: replicas: 3 selector: matchLabels: app: myapp template: metadata: labels: app: myapp spec: containers: - name: myapp image: myapp:v2 ports: - containerPort: 80 strategy: type: RollingUpdate rollingUpdate: maxUnavailable: 1 maxSurge: 1 ``` 这个模板定义了一个 Deployment,名为 `myapp-deployment`,它由 3 个副本组成,副本使用镜像 `myapp:v2`。滚动升级策略是,在升级过程中最多允许 1 个副本不可用,最多允许新副本数量达到 1 个。 请注意,这只是一个简单的模板,实际情况可能会有所不同。例如,您可能希望为 Deployment 设置更复杂的选择器,或者指定更多的容器选项(例如环境变量、卷挂载等)。 希望这个模板对您有帮助! ### 回答2: Kubernetes(简称k8s滚动升级模板是一种描述如何更新Kubernetes集群中的应用程序的计划。下面是一个滚动升级的模板示例: 1. 创建Deployment对象来管理应用程序的部署。 ``` apiVersion: extensions/v1beta1 kind: Deployment metadata: name: my-app spec: replicas: 3 selector: matchLabels: app: my-app template: metadata: labels: app: my-app spec: containers: - name: my-app-container image: my-app:v1 ports: - containerPort: 8080 ``` 2. 执行滚动升级之前,在Deployment对象中更新镜像版本为新的版本。 ``` apiVersion: extensions/v1beta1 kind: Deployment metadata: name: my-app spec: replicas: 3 selector: matchLabels: app: my-app template: metadata: labels: app: my-app spec: containers: - name: my-app-container image: my-app:v2 ports: - containerPort: 8080 ``` 3. 执行kubectl apply命令来应用新的Deployment配置文件,触发滚动升级操作。 ``` kubectl apply -f deployment.yaml ``` 4. Kubernetes将逐步替换集群中的旧Pod实例,并创建新的Pod实例,以确保应用程序在滚动升级过程中保持可用性。此过程根据定义的副本数和滚动升级策略逐步进行。 滚动升级模板为应用程序提供了平滑的升级方式,使得应用程序能够持续提供服务而无需中断。我们可以通过适当定义滚动升级策略,例如最大不可用性和最小可用时间,来控制升级的速度和方式,以最大程度减少对用户的影响。 ### 回答3: 在使用Kubernetes进行滚动升级时,你可以按照以下模板进行操作: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: your-deployment-name labels: app: your-app-label spec: replicas: 3 selector: matchLabels: app: your-app-label template: metadata: labels: app: your-app-label spec: containers: - name: your-container-name image: your-image:your-tag ports: - containerPort: your-port strategy: type: RollingUpdate rollingUpdate: maxUnavailable: 1 maxSurge: 1 ``` 解释: - `your-deployment-name`:你的Deployment的名称,自定义命名。 - `your-app-label`:你的应用的标签,用于选择器和部署中的Pod匹配。 - `your-container-name`:你的容器的名称,自定义命名。 - `your-image:your-tag`:你的容器镜像和标签,指定要使用的镜像及其版本。 - `your-port`:你的容器暴露的端口号,根据实际情况进行修改。 - `maxUnavailable`:在进行滚动升级过程中,最大不可用的Pod数量,这里设置为1。 - `maxSurge`:在进行滚动升级过程中,最大可增加的Pod数量,这里设置为1。 以上模板定义了一个Deployment,它会创建3个Pod,并通过选择器将它们与Deployment关联起来。每个Pod都会运行一个容器,该容器使用指定的镜像和端口号。滚动升级策略被设置为RollingUpdate,最大不可用数量和最大增加数量都为1,以确保在升级期间保持可用性。 你可以将以上模板保存为一个YAML文件,然后使用`kubectl apply -f your-file.yaml`命令进行部署。当你需要升级应用时,可以通过更新镜像和标签,并再次执行`kubectl apply`命令来触发滚动升级过程。Kubernetes会逐步更新Pod,保持应用的可用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云计算-Security

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值