k8s版本升级到1.24.x

本文档详细介绍了如何将k8s集群从1.23版本升级到1.24.x,重点包括控制平面和工作节点的升级步骤。升级涉及kubeadm、kubelet和kubectl的更新,以及节点的腾空和保护解除。1.24.x版本后,k8s不再依赖docker,推荐使用containerd。升级过程中应注意节点的调度状态,确保集群稳定性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

每个版本升级都有对应的文档,以1.23升级到1.24为例。

1.24.6版本后,k8s不再依赖于docker。需要先切换到使用containerd。
可以查看栏目的k8s安装文档。

确定要升级到哪个版本

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

yum list --showduplicates kubeadm --disableexcludes=kubernetes 
 #在列表中查找最新的 1.24 版本 
 #它看起来应该是 1.24.x-0,其中 x 是最新的补丁版本 

升级控制平面节点

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

升级 kubeadm

升级kubeadm过程中会有短暂的集群无法访问的情况,部分pod会重启,如filebeat、dashboard。

对于第一个控制面节点

  • 升级 kubeadm:
# 用最新的补丁版本号替换 1.24.x-0 中的 x
yum install -y kubeadm-1.24.10-0 --disableexcludes=kubernetes 

验证下载操作正常,并且 kubeadm 版本正确:
在这里插入图片描述
验证升级计划:

 kubeadm upgrade plan 

在这里插入图片描述
运行升级的命令。例如:

kubeadm upgrade apply v1.24.10

flannel 网络插件可以不用升级。

升级其它控制节点kubeadm

#yum install -y kubeadm-1.24.10-0 --disableexcludes=kubernetes 
#kubeadm upgrade node

查看是否成功

kubeadm version 

腾空控制节点

通过将某个控制节点标记为不可调度并腾空节点为节点作升级准备:

# 将 <node-to-drain> 替换为你要腾空的控制面节点名称 
kubectl drain <node-to-drain> --ignore-daemonsets

此操作不会影响集群的使用

升级控制节点的 kubelet 和 kubectl

# 用最新的补丁版本号替换 1.24.x-00 中的 x 
yum install -y kubelet-1.24.10-0 kubectl-1.24.10-0 --disableexcludes=kubernetes

重启 kubelet:

systemctl daemon-reload 
systemctl restart kubelet

解除节点的保护

通过将节点标记为可调度,让其重新上线:

# 将 <node-to-drain> 替换为你的节点名称
kubectl uncordon <node-to-drain>

升级工作节点

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

升级步骤与升级控制节点差不多。

升级 kubeadm

# 将 1.26.x-0 中的 x 替换为最新的补丁版本
yum install -y kubeadm-1.26.x-0 --disableexcludes=kubernetes

执行 “kubeadm upgrade”

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

sudo kubeadm upgrade node

腾空节点

将节点标记为不可调度并驱逐所有负载,准备节点的维护:

# 将 <node-to-drain> 替换为你正腾空的节点的名称
kubectl drain <node-to-drain> --ignore-daemonsets

升级 kubelet 和 kubectl

升级 kubelet 和 kubectl:

# 将 1.26.x-0 中的 x 替换为最新的补丁版本
yum install -y kubelet-1.26.x-0 kubectl-1.26.x-0 --disableexcludes=kubernetes

重启 kubelet:

sudo systemctl daemon-reload
sudo systemctl restart kubelet

取消对节点的保护

通过将节点标记为可调度,让节点重新上线:

# 将 <node-to-uncordon> 替换为你的节点名称
kubectl uncordon <node-to-uncordon>

验证集群的状态

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

kubectl get nodes

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

### 安装前准备 为了确保 Kubernetes 能够正常运行于 Ubuntu 上,需先确认系统的版本以及更新状态。对于Ubuntu 服务器版而言,建议使用最新的稳定版本以获得更好的兼容性和安全性支持[^2]。 ```bash sudo apt update && sudo apt upgrade -y ``` ### 配置APT源并安装Docker 考虑到容器化应用的需求,首先应配置 APT 源来启用 HTTPS 方式访问 Docker 的官方仓库,并完成 Docker CE 的安装: ```bash # 设置必要的依赖包以便能够通过HTTPS方式使用apt仓库 sudo apt install ca-y # 添加Docker的官方GPG密钥 curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg # 设置stable通道作为默认来源 echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null # 更新APT包索引 sudo apt-get update # 安装最新版本的Docker Engine和其他组件 sudo apt-get install docker-ce docker-ce-cli containerd.io -y ``` 此部分操作同样适用于 CentOS 和其他 Linux 发行版中的二进制文件安装过程[^3]。 ### 关闭Swap分区 Kubernetes 不允许开启 swap 分区,因此需要关闭它: ```bash sudo sed -i '/swap/d' /etc/fstab # 注释掉fstab里的swap项 sudo swapoff -a # 立即禁用所有交换空间 ``` ### 安装 kubeadm, kubelet 和 kubectl 接下来将设置 Kubernetes 的 APT 存储库,并从中获取 `kubeadm`、`kubelet` 及 `kubectl` 工具用于集群初始化和服务管理: ```bash # 启用k8s存储库 cat <<EOF | sudo tee /etc/modules-load.d/containerd.conf overlay br_netfilter EOF # 加载模块 sudo modprobe overlay sudo modprobe br_netfilter # 设置sysctl参数 cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf net.bridge.bridge-nf-call-ip6tables = 1 net.bridge.bridge-nf-call-iptables = 1 EOF # 应用更改 sudo sysctl --system # 添加Google Cloud GPG key curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add - # 将Kubernetes APT repository添加到系统中 sudo bash -c 'cat <<EOF >/etc/apt/sources.list.d/kubernetes.list deb http://apt.kubernetes.io/ kubernetes-xenial main EOF' # 刷新软件列表并锁定特定版本号(此处假设为v1.24.x系列) sudo apt-get update sudo apt-get install -y kubelet=1.24.* kubeadm=1.24.* kubectl=1.24.* # 锁定这些包不被自动升级覆盖 sudo apt-mark hold kubelet kubeadm kubectl ``` 上述命令会根据当前使用的 Ubuntu 版本来适配合适的 Kubernetes 版本范围[^4]。 ### 初始化 Kubernetes Master Node 当所有的前置条件都满足之后,则可以通过下面这条指令来进行 master node 的初始化工作: ```bash sudo kubeadm init --pod-network-cidr=10.244.0.0/16 ``` 这一步骤将会创建一个新的控制平面节点,并指定 Flannel CNI 插件所需的 IP 地址池 CIDR。 ### 配置 Kubeconfig 文件 为了让普通用户也拥有足够的权限去管理和查看集群的状态信息,还需要做额外的配置处理: ```bash mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config ``` 至此,已经完成了单机版 Kubernetes 在 Ubuntu 平台上的搭建流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiegwei

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值