k8s 滚动更新控制(一)

在传统的应用升级时,通常采用的方式是先停止服务,然后升级部署,最后将新应用启动。这个过程面临一个问题,就是在某段时间内,服务是不可用的,对于用户来说是非常不友好的。而kubernetes滚动更新,将避免这种情况的发生。

对于Kubernetes集群来说,一个service可能有多个pod,滚动升级(RollingUpdate)就是指每次更新部分Pod,直至所有的Pod更新完成,达到平滑升级的效果,而不是在同一时刻将该Service下面的所有Pod停止。

参数配置

spec:

strategy:

type: RollingUpdate

rollingUpdate:

maxSurge: 1

maxUnavailable: 1

字段含义

type:设置更新策略。有两个可选项:recreate和RollingUpdate(默认)。Recreate表示全部重新创建,RollingUpdate表示滚动更新。

maxSurge:升级过程中最多可以比原先设置多出的POD数量,可以是数字,也可以是比例。例如:maxSurage=1,replicas=5,则表示升级过程中最多会有5+1个POD。

升级过程中最多允许有多少个POD处于不可用状态。maxUnavailable =1 表示升级过程中最多会有一个pod可以处于无法服务的状态,在这里就是至少要有5-1个pod正常。

说明:maxSurge和maxUnavaible在更新策略为RollingUpdate时才需要设置。

测试demo

deployment.yaml

apiVersion: apps/v1

kind: Deployment

metadata:

labels:

app: nginx-deploy

name: nginx-deploy

spec:

replicas: 5

revisionHistoryLimit: 10

minReadySeconds: 5

strategy:

type: RollingUpdate

rollingUpdate:

maxSurge: 1

maxUnavailable: 1

selector:

matchLabels:

app: nginx-deploy

template:

metadata:

labels:

app: nginx-deploy

spec:

restartPolicy: Always

containers:

  • name: mynginx

image: nginx:1.23

imagePullPolicy: IfNotPresent

举例:

root@k8s-master \~# kubectl apply -f deployment.yaml

deployment.apps/nginx-deploy created

root@k8s-master \~#

使用nginx:1.23版本启动了5个pod。如下所示:

现在我们进行升级,使用nginx:1.23.1。我这里使用命令行,写到yaml中也可以。

kubectl set image deployment/nginx-deploy mynginx=nginx:1.23.1 --record

通过命令kubectl get pod -w我们可以看到整个清晰地过程,即创建一个pod,再删除一个pod,直至所有的pod被更新完成。

查看下yaml

root@k8s-master \~# kubectl get deploy nginx-deploy -o yaml

apiVersion: apps/v1

kind: Deployment

...

spec:

containers:

  • image: nginx:1.23.1

imagePullPolicy: IfNotPresent

name: mynginx

...

root@k8s-master \~#

可以发现nginx已经被更新为1.23.1版本,更新成功。

版本回退

有版本升级,就会有对应的版本回退。我们可以通过以下命令来完成版本回退。

历史记录

root@k8s-master \~# kubectl rollout history deployment/nginx-deploy

deployment.apps/nginx-deploy

REVISION CHANGE-CAUSE

1 <none>

2 kubectl set image deployment/nginx-deploy mynginx=nginx:1.23.1 --record=true

root@k8s-master \~#

VERSION=1表示最初始的版本。VERSION=2表示一次升级的版本,依次类推...

查看某个版本历史详情

kubectl rollout history deployment/nginx-deploy --revision=1

回滚(回到上次)

kubectl rollout undo deployment/nginx-deploy

回滚(回到指定版本)

kubectl rollout undo deployment/nginx-deploy --to-revision=2

说明:这些命令中的nginx-deploy是部署的名称,换成自己的即可。前面数字表示版本。

注意点

1、更新策略

我们这里使用的是滚动更新RollingUpdate。如何使用Recreate,会和传统的升级方法一样,先停掉所有的pod,然后重建pod。

2、参数设置

当maxSurge设置为0的时候,maxUnavailable不能设置为0。maxSurge=0时先删除后启动,maxSurge!=0时先启动后删除。

3、两个字段说明

spec:

revisionHistoryLimit: 10

minReadySeconds: 5

  • revisionHistoryLimit表示保留的版本数。

  • minReadySeconds表示pod启动后经过多少秒pod才开始对外提供服务。

这两个字段一般都需要设置。

相关推荐
java_cj22 分钟前
从kubectl源码学pprof:生产环境性能分析的实战指南
运维·云原生·容器·kubernetes
吠品31 分钟前
Docker 构建时网络超时拉不到镜像?一些排查和配置记录
云原生·eureka
爱吃龙利鱼2 小时前
K8s 监控实战:victoria-metrics-k8s-stack 高可用部署,资源占用直降 70%,比 Prometheus 省 5 倍磁盘
docker·kubernetes·prometheus
STDD2 小时前
Kubeflow ML 流水线 K8s 部署教程:机器学习工作流编排全攻略
机器学习·容器·kubernetes
牛奶咖啡132 小时前
KVM虚拟化与企业应用实践——通过网络介质配合ks自动应答文件实现自动安装KVM虚拟机
云原生·qemu·kvm·系统网络引导与ks自动应答环境·远程资源+ks文件安装虚拟机·通过网络介质引导自动安装虚拟机·qemu的总线类型详解
爱吃龙利鱼2 小时前
k8s1.36部署helm和storageclass
云原生·容器·kubernetes
yuezhilangniao2 小时前
2026删除K8s命名空间 卡 Terminating 的 ns
java·容器·kubernetes
又是进步的一天2 小时前
一台虚拟机学习CI流程
学习·ci/cd·云原生·容器·kubernetes·devops
IT WorryFree2 小时前
GitHub Actions 流水线注入敏感配置完整方案(Antora + Docker Compose)
docker·容器·github
java_cj2 小时前
从kubectl源码学Cobra:打造专业级Go命令行工具的完整实践
运维·开发语言·后端·云原生·golang·kubernetes·k8s