当前位置: 首页 > news >正文

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才开始对外提供服务。

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

http://www.lryc.cn/news/123505.html

相关文章:

  • Java智慧工地APP源码带AI识别
  • ME3116电源小板
  • 摸准天气“小心思”,躲避恶劣天气“偷袭”
  • Golang 局部变量、全局变量 声明
  • 软考高级之系统架构师之数据通信与计算机网络
  • 牛客网华为OD前端岗位,面试题库练习记录01
  • Python web实战之Django 的缓存机制详解
  • chatserver服务器开发笔记
  • DP——动态规划
  • 【Windows 11】安装 Android子系统 和 Linux子系统
  • 秒杀库存解决方案
  • [免费在线] 将 PDF 转换为 Excel 或 Excel 转换为 PDF | 5 工具
  • PLC求解弹簧质量模型微分方程数值解(RK4梯形图程序)
  • CSDN编程题-每日一练(2023-08-14)
  • 【SA8295P 源码分析】69 - Android 侧添加支持 busybox telnetd 服务
  • OpenCV图像处理——模版匹配和霍夫变换
  • 面试官的几句话,差点让我挂在HTTPS上
  • C语言char**,char*,char s[]赋值
  • 一、Kubernetes介绍与集群架构
  • 基于C#UI Automation自动化测试
  • 深入了解Linux运维的重要性与最佳实践
  • 90 | Python人工智能篇 —— 深度学习算法 Keras基于卷积神经网络的情感分类
  • 自然语言处理从入门到应用——LangChain:记忆(Memory)-[记忆的类型Ⅲ]
  • 【ARM 嵌入式 编译系列 10.3 -- GNU elfutils 工具小结】
  • 黑马项目一阶段面试 项目介绍篇
  • 重构内置类Function原型上的call方法
  • Nginx之lnmp架构
  • C# 使用FFmpeg.Autogen对byte[]进行编解码
  • websocket是多线程的嘛
  • CentOS7.9 禁用22端口,使用其他端口替代