升级 Linux 节点
此页面解释了如何升级使用 kubeadm 创建的 Linux 工作节点。
开始之前
您需要对所有节点具有 shell 访问权限,并且必须配置 kubectl 命令行工具才能与您的集群通信。建议在至少有两个不充当控制平面主机的节点上运行本教程。
要检查版本,请输入kubectl version
。- 熟悉 升级 kubeadm 集群其余部分的过程。您需要在升级 Linux 工作节点之前升级控制平面节点。
更改软件包存储库
如果您使用的是社区拥有的软件包存储库(pkgs.k8s.io
),则需要为所需的 Kubernetes 次要版本启用软件包存储库。这在 更改 Kubernetes 软件包存储库 文档中进行了解释。
注意:旧的软件包存储库(
apt.kubernetes.io
和 yum.kubernetes.io
)已 从 2023 年 9 月 13 日开始弃用和冻结。强烈建议使用 托管在 pkgs.k8s.io
的新软件包存储库,并且必须使用这些存储库才能安装 2023 年 9 月 13 日之后发布的 Kubernetes 版本。弃用的旧存储库及其内容可能会在未来随时删除,恕不另行通知。新的软件包存储库提供从 v1.24.0 开始的 Kubernetes 版本的下载。升级工作节点
升级 kubeadm
升级 kubeadm
# replace x in 1.32.x-* with the latest patch version
sudo apt-mark unhold kubeadm && \
sudo apt-get update && sudo apt-get install -y kubeadm='1.32.x-*' && \
sudo apt-mark hold kubeadm
# replace x in 1.32.x-* with the latest patch version
sudo yum install -y kubeadm-'1.32.x-*' --disableexcludes=kubernetes
调用 “kubeadm upgrade”
对于工作节点,这将升级本地 kubelet 配置
sudo kubeadm upgrade node
驱逐节点
通过将节点标记为不可调度并驱逐工作负载来为维护准备节点
# execute this command on a control plane node
# replace <node-to-drain> with the name of your node you are draining
kubectl drain <node-to-drain> --ignore-daemonsets
升级 kubelet 和 kubectl
升级 kubelet 和 kubectl
# replace x in 1.32.x-* with the latest patch version sudo apt-mark unhold kubelet kubectl && \ sudo apt-get update && sudo apt-get install -y kubelet='1.32.x-*' kubectl='1.32.x-*' && \ sudo apt-mark hold kubelet kubectl
# replace x in 1.32.x-* with the latest patch version sudo yum install -y kubelet-'1.32.x-*' kubectl-'1.32.x-*' --disableexcludes=kubernetes
重启 kubelet
sudo systemctl daemon-reload sudo systemctl restart kubelet
取消封锁节点
通过将节点标记为可调度来使节点重新联机
# execute this command on a control plane node
# replace <node-to-uncordon> with the name of your node
kubectl uncordon <node-to-uncordon>
下一步
- 了解如何 升级 Windows 节点。
上次修改时间:2024 年 9 月 13 日下午 4:59 PST:重新组织 kubeadm 节点任务 (c8bb00db5d)