目录
- 前言
- 一、原理概念
- 二、实操
- 1.小技巧
- 2.前置准备
- 3.回滚版本
- 三、总结
前言
各位小伙伴们好鸭,今天咱们的澳同学来提了一个问题:
小涛,我想回滚之前的改的deploy、sts 这些yaml文件,该怎么办鸭
小涛:这好办,用rollout
澳同学:啊?这是啥?
小涛:嘿嘿,咱们来看看
一、原理概念
kubectl rollout
是 Kubernetes 中的一个命令,用于管理资源的部署过程。该命令允许查看部署的状态、暂停、恢复和撤回部署
主要子命令包括:
history:查看资源的版本历史
pause:暂停部署。
restart:重新启动部署。
resume:恢复部署。
status:查看部署的状态。
undo:撤回到之前的版本。
二、实操
1.小技巧
一般这么用:
kubectl rollout status
命令:持续观察部署的状态,直到完成或失败。 kubectl rollout undo
:部署出现问题,快速回滚到之前的版本。kubectl rollout pause
: 更新配置或镜像前,先暂停部署,可确保所有更改都是预期的。kubectl rollout history
:查看部署的历史记录,包括每个版本的更改。
2.前置准备
# 创建一个pod
kubectl run nginx-dep --image=hub-galaxy.cstwo.com/ksyun/nginx:1.9.1 --port=80 --replicas=2 -n default --record
# --record 【记录相应的操作历史到资源的注解中】
接下来我们更新一个版本【更新镜像版本】
kubectl set image deploy nginx-test -n default nginx-test=nginx:v2.0 --record
kubectl rollout history -n default deploy nginx-test #查看历史版本,方便回滚
3.回滚版本
#查看当前历史版本
kubectl rollout history -n default deploy nginx-test
#回滚至上一版本【备注:--to-revision 是指定回滚的版本,若不加改参数,默认回滚至上一版本】
kubectl rollout undo deploy -n default nginx-test --to-revision=1
#查看镜像名称是否改变【验证回滚是否符合预期】
kubectl get deploy -n default nginx-test -o yaml |grep -i image:
OK~ 回滚完成
三、总结
总的来说,kubectl rollout
具有以下功能,通过与 Kubernetes 中的控制器对象交互,控制 Pod 的更新和替换过程,以实现应用程序的滚动更新和回滚操作。
- 控制器管理:kubectl rollout 实际上是与 Kubernetes 中的控制器对象(如Deployment、DaemonSet、StatefulSet 等)交互,控制器负责管理和调度 Pod 的创建、更新和删除。
- 更新策略:在执行滚动更新时,kubectl rollout 会根据控制器的更新策略(如滚动更新策略、并行更新策略等)来决定更新的方式和速度,以确保更新过程的可控性和安全性。
- 更新过程:滚动更新通常包括三个阶段:先创建新的 Pod,然后逐步替换旧的 Pod,最后删除旧的 Pod。kubectl rollout会监控这一过程,确保更新顺利进行。
- 回滚操作:如果更新过程中出现问题,可以使用 kubectl rollout undo 命令回滚到先前的版本。这会重新调度Pod,将应用程序恢复到更新前的状态。
- 监控与反馈:kubectl rollout 提供了查看更新状态和历史记录的功能,可以通过这些信息来监控更新过程的进展,并及时采取措施处理异常情况。
澳同学:不错不错,看来学得挺扎实的,下次继续换别的问题考考你
小涛:好嘞 😭
又是充实的一天,小涛继续学习去了,冲冲冲,咱们下篇博客再见了~ ヾ(•ω•`)o