在我们发布容器中的服务时,总共有一下几种方式:
kubectl create -f deply.yaml --record
kubectl patch deployment deploymentName -p
kubectl set image deployment deploymentName
kubectl rollout status
kubectl rollout history deployment kubia
kubectl rollout undo deployment kubia
回滚Deployment到指定版本:kubectl rollout undo deployment kubia --to-revision=1
方法 | 作用 | 例子 |
---|---|---|
kubectl edit | 使用默认编辑器打开资源配置。修改保存并退出编辑器,资源对象会被更新 | kubectl edit deployment kubia |
kubectl patch | 修改单个资源属性 | kubectl patch deployment deploymentName -p json格式的数据 |
kubectl apply | 通过一个完整的yaml或json文件来修改资源,如果文件中定义的资源不存在,会创建一个。文件中对资源的描述必须全面,不能像patch那样 | kubectl apply -f kubia-deploy.yaml |
kubectl replace | 将原有对象替换为yaml/json中定义的新对象。如果原有对象不存在,会报错 | kubectl replace -f kubia-deploy.yaml |
kubectl set image | 修改pod、rs、rc、deployment、DemonSet、job中的镜像 | kubectl set image deployment kubia nodejs=luksa/kubia:v2 |
以上这些方式修改完Deployment资源后,会自动触发滚动升级
注意:如果Deployment的pod模板引用了一个configmap/secret,那么更改configmap资源不会触发升级。需要创建一个新的configmap
然后需改pod模板引用新的configmap。
apiVersion: apps/v1
kind: Deployment
metadata:
name: app
spec:
selector:
matchLabels:
name: app
strategy:
rollingUpdate:
# 决定了在升级过程中最多允许超出期待副本数的数量,默认为25%
# 如果期待副本数为4,那么运行时不会超过5个pod实例
# 如果设置的不是百分数的化,则代表的允许的最大超过数量,下面这个就是指最大超过一个
maxSurge: 1
# 决定了在升级过程中,最多允许多少个pod处于不可用状态,默认为25%
# 如果期待数量为4,那么可用的pod数量最低为3
# 如果设置的不是百分数的化,则代表的允许的最大不可用数量,下面这个就是指最大不可用数为一个
maxUnavailable: 0
目前还无法实现在一个确定的位置暂时滚动升级以达到金丝雀发布,所以上述方法还不健全。
可以操作的是可以创建两个不同的deployment,然后通过控制其pod数量来实现金丝雀发布
kubectl rollout pause deployment kubia
kubectl rollout resume deployment kubia
因为修改Deployment时会自动触发滚动升级,如果不想立即升级,可以通过不停的使用暂停滚动升级,直到对deployment的修改完毕后,再恢复滚动升级。
可以通过Deployment的spec.minReadySeconds和就绪探针实现,升级过程中发现新版本故障,自动停止升级。
minReadySeconds指的是,新创建的pod至少要成功运行多久之后 ,才能将其视为可用,在这个期间内,deployment不会继续滚动升级,除非这个pod已经被视为可用。
在升级过程中,pod的就绪探针返回成功后,kubernetes才会视为pod可用,而在deployment升级过程中只有在minReadySeconds时间内,
pod的就绪探针没有返回过失败,才会判断为这个新版本pod发布没有问题,然后继续后面的滚动升级动作,否则会阻止滚动升级。
可以通过设置Deployment的spec.progressDeadlineSeconds值来定义升级的时间限制,如果在设置时间内没有完成升级,则会停止升级动作。
原文:https://www.cnblogs.com/yechen2019/p/12197873.html