树叶云kubernetes教程:Kubernetes 升级kubeadm集群

在开始之前

  • 务必仔细认真阅读发行说明。
  • 集群应使用静态的控制平面和 etcd Pod 或者外部 etcd。
  • 务必备份所有重要组件,例如存储在数据库中应用层面的状态。 ​kubeadm upgrade​ 不会影响你的工作负载,只会涉及 Kubernetes 内部的组件,但备份终究是好的。
  • 必须禁用交换分区。

附加信息

  • 下述说明了在升级过程中何时腾空每个节点。如果你正在对任何 kubelet 进行小版本升级, 你需要先腾空待升级的节点(或多个节点)。对于控制面节点,其上可能运行着 CoreDNS Pods 或者其它非常重要的负载。
  • 升级后,因为容器规约的哈希值已更改,所有容器都会被重新启动。
  • 要验证 kubelet 服务在升级后是否成功重启,可以执行 ​systemctl status kubelet​ 或 ​journalctl -xeu kubelet​ 查看服务日志。
  • 不建议使用 ​kubeadm upgrade​ 的 `–config 参数和 kubeadm 配置 API 类型 来重新配置集群,这样会产生意想不到的结果。

确定要升级到哪个版本

使用操作系统的包管理器找到最新的补丁版本 Kubernetes 1.24:

  • Ubuntu、Debian 或 HypriotOS
  • apt update
    apt-cache madison kubeadm
    # 在列表中查找最新的 1.24 版本
    # 它看起来应该是 1.24.x-00,其中 x 是最新的补丁版本
  • CentOS、RHEL 或 Fedora
  • yum list --showduplicates kubeadm --disableexcludes=kubernetes
    # 在列表中查找最新的 1.24 版本
    # 它看起来应该是 1.24.x-0,其中 x 是最新的补丁版本

升级控制平面节点 

控制面节点上的升级过程应该每次处理一个节点。 首先选择一个要先行升级的控制面节点。该节点上必须拥有 ​/etc/kubernetes/admin.conf​ 文件。

执行 “kubeadm upgrade”

升级第一个控制面节点

  1. 升级 kubeadm:
    • Ubuntu、Debian 或 HypriotOS
    • # 用最新的补丁版本号替换 1.24.x-00 中的 x
      apt-mark unhold kubeadm && \
      apt-get update && apt-get install -y kubeadm=1.24.x-00 && \
      apt-mark hold kubeadm
      -
    • CentOS、RHEL 或 Fedora
    • # 用最新的补丁版本号替换 1.24.x-0 中的 x
      yum install -y kubeadm-1.24.x-0 --disableexcludes=kubernetes
  2. 验证下载操作正常,并且 kubeadm 版本正确:
  3. kubeadm version
    
  4. 验证升级计划:
  5. kubeadm upgrade plan
    

    此命令检查你的集群是否可被升级,并取回你要升级的目标版本。 命令也会显示一个包含组件配置版本状态的表格。

    Note:


    kubeadm upgrade​ 也会自动对 kubeadm 在节点上所管理的证书执行续约操作。 如果需要略过证书续约操作,可以使用标志 ​
    --certificate-renewal=false​。

    Note:

    如果 ​
    kubeadm upgrade plan​ 给出任何需要手动升级的组件配置,用户必须 通过 ​
    --config​ 命令行标志向 ​
    kubeadm upgrade apply​ 命令提供替代的配置文件。 如果不这样做,​
    kubeadm upgrade apply​ 会出错并退出,不再执行升级操作。

    选择要升级到的目标版本,运行合适的命令。例如:

    # 将 x 替换为你为此次升级所选择的补丁版本号
    sudo kubeadm upgrade apply v1.24.x

    一旦该命令结束,你应该会看到:

    [upgrade/successful] SUCCESS! Your cluster was upgraded to "v1.24.x". Enjoy!
    
    [upgrade/kubelet] Now that your control plane is upgraded, please proceed with upgrading your kubelets if you haven't already done so.
  6. 手动升级你的 CNI 驱动插件。
  7. 你的容器网络接口(CNI)驱动应该提供了程序自身的升级说明。

    如果 CNI 驱动作为 DaemonSet 运行,则在其他控制平面节点上不需要此步骤。

对于其它控制面节点

与第一个控制面节点相同,但是使用:

sudo kubeadm upgrade node

而不是:

sudo kubeadm upgrade apply

此外,不需要执行 ​kubeadm upgrade plan​ 和更新 CNI 驱动插件的操作。

腾空节点

  • 通过将节点标记为不可调度并腾空节点为节点作升级准备:
  • # 将 <node-to-drain> 替换为你要腾空的控制面节点名称
    kubectl drain <node-to-drain> --ignore-daemonsets

升级 kubelet 和 kubectl 

  1. 升级 kubelet 和 kubectl:
    • Ubuntu、Debian 或 HypriotOS
    • ```shell
      # 用最新的补丁版本替换 1.24.x-00 中的 x
      apt-mark unhold kubelet kubectl && \
      apt-get update && apt-get install -y kubelet=1.24.x-00 kubectl=1.24.x-00 && \
      apt-mark hold kubelet kubectl
      ```
    • CentOS、RHEL 或 Fedora
    • ```shell
      # 用最新的补丁版本号替换 1.24.x-00 中的 x
      yum install -y kubelet-1.24.x-0 kubectl-1.24.x-0 --disableexcludes=kubernetes
      ```
  2. 重启 kubelet
  3. sudo systemctl daemon-reload
    sudo systemctl restart kubelet

解除节点的保护

  • 通过将节点标记为可调度,让其重新上线:
  • # 将 <node-to-drain> 替换为你的节点名称
    kubectl uncordon <node-to-drain>

升级工作节点 

工作节点上的升级过程应该一次执行一个节点,或者一次执行几个节点, 以不影响运行工作负载所需的最小容量。

升级 kubeadm

  • Ubuntu、Debian 或 HypriotOS
  • # 将 1.24.x-00 中的 x 替换为最新的补丁版本号
    apt-mark unhold kubeadm && \
    apt-get update && apt-get install -y kubeadm=1.24.x-00 && \
    apt-mark hold kubeadm
  • CentOS、RHEL 或 Fedora
  • # 用最新的补丁版本替换 1.24.x-00 中的 x
    yum install -y kubeadm-1.24.x-0 --disableexcludes=kubernetes

执行 “kubeadm upgrade”

  • 对于工作节点,下面的命令会升级本地的 kubelet 配置:
  • sudo kubeadm upgrade node
    

腾空节点 

  • 将节点标记为不可调度并驱逐所有负载,准备节点的维护:
  • # 将 <node-to-drain> 替换为你正在腾空的节点的名称
    kubectl drain <node-to-drain> --ignore-daemonsets

升级 kubelet 和 kubectl

  1. 升级 kubelet 和 kubectl:
    • Ubuntu、Debian 或 HypriotOS
    • # 将 1.24.x-00 中的 x 替换为最新的补丁版本
      apt-mark unhold kubelet kubectl && \
      apt-get update && apt-get install -y kubelet=1.24.x-00 kubectl=1.24.x-00 && \
      apt-mark hold kubelet kubectl
    • CentOS, RHEL or Fedora
    • # 将 1.24.x-0 x 替换为最新的补丁版本
      yum install -y kubelet-1.24.x-0 kubectl-1.24.x-0 --disableexcludes=kubernetes
  2. 重启 kubelet
  3. sudo systemctl daemon-reload
    sudo systemctl restart kubelet

取消对节点的保护

  • 通过将节点标记为可调度,让节点重新上线:
  • # 将 <node-to-drain> 替换为当前节点的名称
    kubectl uncordon <node-to-drain>

验证集群的状态 

在所有节点上升级 kubelet 后,通过从 kubectl 可以访问集群的任何位置运行以下命令, 验证所有节点是否再次可用:

kubectl get nodes

STATUS ​应显示所有节点为 ​Ready ​状态,并且版本号已经被更新。

从故障状态恢复

如果 ​kubeadm upgrade​ 失败并且没有回滚,例如由于执行期间节点意外关闭, 你可以再次运行 ​kubeadm upgrade​。 此命令是幂等的,并最终确保实际状态是你声明的期望状态。 要从故障状态恢复,你还可以运行 ​kubeadm upgrade --force​ 而无需更改集群正在运行的版本。

在升级期间,kubeadm 向 ​/etc/kubernetes/tmp​ 目录下的如下备份文件夹写入数据:

  • kubeadm-backup-etcd-<date>-<time>
  • kubeadm-backup-manifests-<date>-<time>

kubeadm-backup-etcd​ 包含当前控制面节点本地 etcd 成员数据的备份。 如果 etcd 升级失败并且自动回滚也无法修复,则可以将此文件夹中的内容复制到 ​/var/lib/etcd​ 进行手工修复。如果使用的是外部的 etcd,则此备份文件夹为空。

kubeadm-backup-manifests​ 包含当前控制面节点的静态 Pod 清单文件的备份版本。 如果升级失败并且无法自动回滚,则此文件夹中的内容可以复制到 ​/etc/kubernetes/manifests​ 目录实现手工恢复。 如果由于某些原因,在升级前后某个组件的清单未发生变化,则 kubeadm 也不会为之 生成备份版本。

工作原理 

kubeadm upgrade apply​ 做了以下工作:

  • 检查你的集群是否处于可升级状态:
    • API 服务器是可访问的
    • 所有节点处于 Ready 状态
    • 控制面是健康的
  • 强制执行版本偏差策略。
  • 确保控制面的镜像是可用的或可拉取到服务器上。
  • 如果组件配置要求版本升级,则生成替代配置与/或使用用户提供的覆盖版本配置。
  • 升级控制面组件或回滚(如果其中任何一个组件无法启动)。
  • 应用新的 ​CoreDNS ​和 ​kube-proxy​ 清单,并强制创建所有必需的 RBAC 规则。
  • 如果旧文件在 180 天后过期,将创建 API 服务器的新证书和密钥文件并备份旧文件。

kubeadm upgrade node​ 在其他控制平节点上执行以下操作:

  • 从集群中获取 kubeadm ​ClusterConfiguration​。
  • (可选操作)备份 kube-apiserver 证书。
  • 升级控制平面组件的静态 Pod 清单。
  • 为本节点升级 kubelet 配置

kubeadm upgrade node​ 在工作节点上完成以下工作:

  • 从集群取回 kubeadm ​ClusterConfiguration​。
  • 为本节点升级 kubelet 配置。

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/157343.html<

(0)
管理的头像管理
上一篇2025-03-16 08:10
下一篇 2025-03-16 08:11

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注