升级 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.33.x-* with the latest patch version
sudo apt-mark unhold kubeadm && \
sudo apt-get update && sudo apt-get install -y kubeadm='1.33.x-*' && \
sudo apt-mark hold kubeadm
# replace x in 1.33.x-* with the latest patch version
sudo yum install -y kubeadm-'1.33.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.33.x-* with the latest patch version sudo apt-mark unhold kubelet kubectl && \ sudo apt-get update && sudo apt-get install -y kubelet='1.33.x-*' kubectl='1.33.x-*' && \ sudo apt-mark hold kubelet kubectl
# replace x in 1.33.x-* with the latest patch version sudo yum install -y kubelet-'1.33.x-*' kubectl-'1.33.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)