K8S学习之基础十六:k8s中Deployment更新策略

滚动更新

滚动更新是一种自动化程度较高的发布方式、用户体验比较平滑、是目前成熟型技术组织采用的主流发布方式,一次滚动发布一般有若干发布批次组成,每批的数量一般都是可配置的,可通过发布模板定义,例如第一批10%,第二批30%,第三批60%,第四批40%。每个批次之间保留观察间隔,通过手工验证或监控反馈确保没有问题再发下一批次。所以总体上滚动发布的过程是比较缓慢的。

默认的更新策略 maxSurge: 25% maxUnavailable: 25%

复制代码
vi deploy-demo.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp-v1
spec:
  replicas: 10
  selector:
    matchLabels:
      app: myapp
      version: v1
  template:
    metadata:
      labels:
        app: myapp
        version: v1
    spec:
      containers:
      - name: myapp
        image: 172.16.80.140/myapp/myapp:v1
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80

将yaml中的版本修改为v2,重新应用,会发现生成一个新的rs,按照滚动策略进行更新pod,最终所有的pod都跟更新为新的版本,老的rs停用

查看新的pod,请求的结果与之前版本不同,说明已经更新为新的版本

查看历史版本

kubectl rollout history deployment myapp-v1

版本回滚,pod又恢复成v1版本

kubectl rollout history undo deployment/myapp-v1 --to-revision=1

自定义更新策略

yaml中配置maxSurge和maxUnavailable的值,两者不能同时为0

maxSurge==1 maxUnavailable 增加一个删除一个,速度较慢

也可以通过patch更新:

kubectl patch deployment myapp-v1 -p '{"spec":{"strategy":{"rollingUpdate": {"maxSurge":1,"maxUnavailable":1}}}}'

kubectl describe deployment myapp-v1 | grep RollingUpdateStrategy

更新策略默认是RollingUpdate,还有一种Recreata,把所有的pod都删掉重新创建,如下图,如果没有红框内容,默认RollingUpdate更新策略,如果有红框内容,更新策略改为Recreate

相关推荐
就叫飞六吧7 小时前
基于汇编实现led点灯-51单片机-stc89c52rc
嵌入式硬件·学习
Larry_Yanan7 小时前
QML学习笔记(二十四)QML的Keys附加属性
c++·笔记·qt·学习·ui
Chunyyyen7 小时前
【第十六周】自然语言处理的学习笔记01
笔记·学习·自然语言处理
我命由我123458 小时前
Photoshop - Photoshop 工具栏(5)多边套索工具
笔记·学习·ui·职场和发展·photoshop·ps·美工
_dindong9 小时前
动规:回文串问题
笔记·学习·算法·leetcode·动态规划·力扣
Zwb2997929 小时前
Day 30 - 错误、异常与 JSON 数据 - Python学习笔记
笔记·python·学习·json
不太可爱的叶某人10 小时前
【学习笔记】kafka权威指南——第7章 构建数据管道(7-10章只做了解)
笔记·学习·kafka
Broken Arrows10 小时前
k8s学习(二)——kubernetes整体架构及组件解析
学习·架构·kubernetes
小年糕是糕手10 小时前
【数据结构】算法复杂度
c语言·开发语言·数据结构·学习·算法·leetcode·排序算法
蓑笠翁00111 小时前
从零开始学习Python Django:从环境搭建到第一个 Web 应用
python·学习·django