博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Kubernetes Pod应用的滚动更新(八)
阅读量:6380 次
发布时间:2019-06-23

本文共 3680 字,大约阅读时间需要 12 分钟。

一、环境准备

我们紧接上一节的环境,进行下面的操作,如果不清楚的,可以先查看上一篇博文。

滚动更新是一次只更新一小部分副本,成功后,再更新更多的副本,最终完成所有副本的更新。滚动更新的最大的好处是零停机,整个更新过程始终有副本在运行,从而保证了业务的连续性。

二、更新

我们查看一下上一节的配置文件mytest-deploy.yaml

apiVersion: extensions/v1beta1kind: Deploymentmetadata:  name: mytestspec:  replicas: 3  template:    metadata:      labels:        run: mytest    spec:      containers:      - name: mytest        image: wangzan18/mytest:v1        ports:        - containerPort: 80

我们看到设定的镜像版本为v1,我们查看一下创建的ReplicaSet

[root@master ~]# kubectl get rs -o wideNAME               DESIRED   CURRENT   READY   AGE   CONTAINERS   IMAGES                SELECTORmytest-88d46bf99   3         3         3       68m   mytest       wangzan18/mytest:v1   pod-template-hash=88d46bf99,run=mytest

目前运行的 Pod 由 ReplicaSet mytest-88d46bf99进行控制,我们将配置文件中的 v1 替换为 v2,再次应用。

[root@master ~]# kubectl apply -f mytest-deploy.yaml deployment.extensions/mytest configured[root@master ~]# kubectl get podsNAME                     READY   STATUS        RESTARTS   AGEmytest-56c55b4c6-6gjxc   1/1     Running       0          24smytest-56c55b4c6-f5trx   1/1     Running       0          18smytest-56c55b4c6-sh5wd   1/1     Running       0          24smytest-88d46bf99-48f6n   1/1     Terminating   0          70mmytest-88d46bf99-mv6cf   1/1     Terminating   0          70mmytest-88d46bf99-p9w79   1/1     Terminating   0          70m
[root@master ~]# kubectl get deploy -o wideNAME     READY   UP-TO-DATE   AVAILABLE   AGE   CONTAINERS   IMAGES                SELECTORmytest   3/3     3            3           72m   mytest       wangzan18/mytest:v2   run=mytest[root@master ~]# kubectl get rs -o wideNAME               DESIRED   CURRENT   READY   AGE   CONTAINERS   IMAGES                SELECTORmytest-56c55b4c6   3         3         3       59s   mytest       wangzan18/mytest:v2   pod-template-hash=56c55b4c6,run=mytestmytest-88d46bf99   0         0         0       71m   mytest       wangzan18/mytest:v1   pod-template-hash=88d46bf99,run=mytest

我们可以看到 Deployment 的镜像更新为wangzan18/mytest:v2,创建了新的 ReplicaSet mytest-56c55b4c6,并管理了三个新的 Pod。

[root@master ~]# kubectl describe deployment mytestEvents:  Type    Reason             Age   From                   Message  ----    ------             ----  ----                   -------  Normal  ScalingReplicaSet  4m9s  deployment-controller  Scaled up replica set mytest-56c55b4c6 to 1  Normal  ScalingReplicaSet  4m9s  deployment-controller  Scaled down replica set mytest-88d46bf99 to 2  Normal  ScalingReplicaSet  4m9s  deployment-controller  Scaled up replica set mytest-56c55b4c6 to 2  Normal  ScalingReplicaSet  4m3s  deployment-controller  Scaled down replica set mytest-88d46bf99 to 1  Normal  ScalingReplicaSet  4m3s  deployment-controller  Scaled up replica set mytest-56c55b4c6 to 3  Normal  ScalingReplicaSet  4m3s  deployment-controller  Scaled down replica set mytest-88d46bf99 to 0

每次只更新替换一个 Pod。

三、回滚

kubectl apply 每次更新应用时 Kubernetes 都会记录下当前的配置,保存为一个 revision(版次),这样就可以回滚到某个特定 revision。

默认配置下,Kubernetes 只会保留最近的几个 revision,可以在 Deployment 配置文件中通过 revisionHistoryLimit 属性增加 revision 数量。

通过命令kubectl rollout undo我们可以回滚到上一个版本。

[root@master ~]# kubectl rollout undo deploy mytestdeployment.extensions/mytest rolled back
[root@master ~]# kubectl get rs -o wideNAME               DESIRED   CURRENT   READY   AGE   CONTAINERS   IMAGES                SELECTORmytest-56c55b4c6   0         0         0       12m   mytest       wangzan18/mytest:v2   pod-template-hash=56c55b4c6,run=mytestmytest-88d46bf99   3         3         3       82m   mytest       wangzan18/mytest:v1   pod-template-hash=88d46bf99,run=mytest

可以看到三个 Pod 重新由镜像为wangzan18/mytest:v1的ReplicaSet进行接管。

转载于:https://blog.51cto.com/wzlinux/2328833

你可能感兴趣的文章
通用唯一标识码UUID的介绍及使用。
查看>>
spring笔记--依赖注入之针对不同类型变量的几种注入方式
查看>>
Ajax的简单学习
查看>>
为npm配置taobao源
查看>>
管理邮件用户
查看>>
导出DC数据以便以介质方式安装另一台域控制器
查看>>
Hibernate学习(八):检索方式
查看>>
基于WorsPress+Xampp搭建博客
查看>>
javascript的一些基本概念
查看>>
关于Tomcat上请求的编解码问题
查看>>
WPF“动画序列”框架的初步研究与实现(附源码)
查看>>
Windows Server 2008 多元密码策略配置
查看>>
.NET中的泛型和Java泛型中的类型擦除
查看>>
白利用的集大成者:新型远控木马上演移形换影大法
查看>>
2017必备的八款最佳反勒索软件工具
查看>>
从Effective Java总结一些有助安卓开发的建议
查看>>
以一当十的程序员不是传说
查看>>
云纵发布“纵横客“ 新一代互联网CRM开启餐饮行业营销新模式
查看>>
物联网到底何时才能称为“爆发”?
查看>>
《Java多线程编程核心技术》——1.2节使用多线程
查看>>