【Kubernetes】kubectl rollout 回滚操作

2024-04-11 13:20

本文主要是介绍【Kubernetes】kubectl rollout 回滚操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 前言
  • 一、原理概念
  • 二、实操
    • 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 的更新和替换过程,以实现应用程序的滚动更新和回滚操作。

  1. 控制器管理:kubectl rollout 实际上是与 Kubernetes 中的控制器对象(如Deployment、DaemonSet、StatefulSet 等)交互,控制器负责管理和调度 Pod 的创建、更新和删除。
  2. 更新策略:在执行滚动更新时,kubectl rollout 会根据控制器的更新策略(如滚动更新策略、并行更新策略等)来决定更新的方式和速度,以确保更新过程的可控性和安全性。
  3. 更新过程:滚动更新通常包括三个阶段:先创建新的 Pod,然后逐步替换旧的 Pod,最后删除旧的 Pod。kubectl rollout会监控这一过程,确保更新顺利进行。
  4. 回滚操作:如果更新过程中出现问题,可以使用 kubectl rollout undo 命令回滚到先前的版本。这会重新调度Pod,将应用程序恢复到更新前的状态。
  5. 监控与反馈:kubectl rollout 提供了查看更新状态和历史记录的功能,可以通过这些信息来监控更新过程的进展,并及时采取措施处理异常情况。

澳同学:不错不错,看来学得挺扎实的,下次继续换别的问题考考你
小涛:好嘞 😭

又是充实的一天,小涛继续学习去了,冲冲冲,咱们下篇博客再见了~ ヾ(•ω•`)o

这篇关于【Kubernetes】kubectl rollout 回滚操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/894197

相关文章

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

什么是Kubernetes PodSecurityPolicy?

@TOC 💖The Begin💖点点关注,收藏不迷路💖 1、什么是PodSecurityPolicy? PodSecurityPolicy(PSP)是Kubernetes中的一个安全特性,用于在Pod创建前进行安全策略检查,限制Pod的资源使用、运行权限等,提升集群安全性。 2、为什么需要它? 默认情况下,Kubernetes允许用户自由创建Pod,可能带来安全风险。

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

MySQL——表操作

目录 一、创建表 二、查看表 2.1 查看表中某成员的数据 2.2 查看整个表中的表成员 2.3 查看创建表时的句柄 三、修改表 alter 3.1 重命名 rename 3.2 新增一列 add 3.3 更改列属性 modify 3.4 更改列名称 change 3.5 删除某列 上一篇博客介绍了库的操作,接下来来看一下表的相关操作。 一、创建表 create

kubernetes集群部署Zabbix监控平台

一、zabbix介绍 1.zabbix简介 Zabbix是一个基于Web界面的分布式系统监控的企业级开源软件。可以监视各种系统与设备的参数,保障服务器及设备的安全运营。 2.zabbix特点 (1)安装与配置简单。 (2)可视化web管理界面。 (3)免费开源。 (4)支持中文。 (5)自动发现。 (6)分布式监控。 (7)实时绘图。 3.zabbix的主要功能