k8s版本升级到1.24.x

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

每个版本升级都有对应的文档,以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 状态,并且版本号已经被更新。

<think>我们参考了提供的多个引用,特别是引用[1]和[2]都提到了在Ubuntu 22.04上搭建Kubernetes环境,但引用[1]是1.24.3版本,引用[2]是1.25.3版本,且都移除了Dockershim,因此我们需要选择容器运行时(如containerd)。由于用户需要单机版本,我们可以使用minikube或者kubeadm的单节点集群(非高可用)方式。不过,引用中提到的都是多节点集群,所以我们需要调整步骤为单节点。 考虑到用户希望搭建的是k8s单机版本(即只有一个节点,既是master也是worker),我们可以使用kubeadm创建一个单节点集群。同时,由于Kubernetes 1.24及以上版本不再支持Docker作为容器运行时,我们将使用containerd。 以下步骤基于引用[1]、[2]、[4]整理,并调整为单节点步骤: 注意:以下操作需要在Ubuntu 22.04系统上以root用户或具有sudo权限的用户执行。 步骤1:环境准备(所有操作在单节点上执行) - 确保系统为Ubuntu 22.04 - 配置主机名(例如k8s-single)并更新/etc/hosts - 关闭交换空间(swap) - 配置必要的系统参数 步骤2:安装容器运行时(containerd) - 安装containerd并配置 步骤3:安装kubeadm, kubelet, kubectl - 添加Kubernetes仓库,安装三件套 步骤4:初始化单节点集群 - 使用kubeadm init创建单节点集群(注意添加参数使之成为单节点) 步骤5:配置kubectl 步骤6:安装网络插件(CNI) 详细步骤: ### 1. 环境配置 #### 1.1 设置主机名 ```bash sudo hostnamectl set-hostname k8s-single # 设置主机名 echo "127.0.0.1 k8s-single" | sudo tee -a /etc/hosts # 添加本地解析 ``` #### 1.2 关闭swap ```bash sudo swapoff -a # 临时关闭 sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab # 永久关闭,注释swap行 ``` #### 1.3 配置系统内核参数 ```bash cat <<EOF | sudo tee /etc/modules-load.d/k8s.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-iptables = 1 net.bridge.bridge-nf-call-ip6tables = 1 net.ipv4.ip_forward = 1 EOF sudo sysctl --system ``` #### 1.4 配置防火墙(如果使用ufw) ```bash sudo ufw disable ``` ### 2. 安装容器运行时(containerd) #### 2.1 安装containerd ```bash # 安装依赖 sudo apt-get update sudo apt-get install -y ca-certificates curl gnupg # 添加Docker官方GPG密钥 sudo mkdir -m 0755 -p /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg # 设置Docker仓库 echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \ $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null # 安装containerd sudo apt-get update sudo apt-get install -y containerd.io # 配置containerd sudo mkdir -p /etc/containerd containerd config default | sudo tee /etc/containerd/config.toml # 修改配置文件,启用SystemdCgroup(如果需要,Kubernetes推荐使用systemd作为cgroup驱动) sudo sed -i 's/SystemdCgroup = false/SystemdCgroup = true/g' /etc/containerd/config.toml # 重启containerd sudo systemctl restart containerd sudo systemctl enable containerd ``` ### 3. 安装kubeadm, kubelet, kubectl #### 3.1 添加Kubernetes仓库和密钥 ```bash sudo apt-get update sudo apt-get install -y apt-transport-https ca-certificates curl # 添加阿里云镜像的Kubernetes仓库 curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | sudo apt-key add - # 添加apt源 cat <<EOF | sudo tee /etc/apt/sources.list.d/kubernetes.list deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main EOF sudo apt-get update ``` #### 3.2 安装指定版本(例如1.24.3,但用户没有指定版本,我们选择较稳定的1.24.x,注意与Ubuntu22.04兼容) ```bash sudo apt-get install -y kubelet=1.24.3-00 kubeadm=1.24.3-00 kubectl=1.24.3-00 sudo apt-mark hold kubelet kubeadm kubectl # 防止自动更新 ``` ### 4. 初始化单节点集群 #### 4.1 使用kubeadm初始化(注意:这里我们使用`--pod-network-cidr`指定flannel网络插件需要的网段,同时使用`--apiserver-advertise-address`绑定到本机IP(如果不需要外部访问可绑定127.0.0.1)?但是单机通常绑定本机内网IP或0.0.0.0?但0.0.0.0不安全,通常绑定节点的实际IP。这里假设节点IP为192.168.247.100(根据引用[2]的示例),请替换为你的实际IP) ```bash # 替换为你机器的实际IP,如果是本机测试,可以用127.0.0.1,但这样集群只能本机访问。为了后续扩展,建议使用内网IP。 sudo kubeadm init \ --apiserver-advertise-address=192.168.247.100 \ --pod-network-cidr=10.244.0.0/16 \ --ignore-preflight-errors=Swap # 如果前面已经关闭了swap,可以不加这个参数 # 如果是单节点集群,我们还需要移除master节点的污点,以便在该节点上调度Pod # 初始化完成后,按照提示执行以下命令(普通用户) mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config # 移除污点 kubectl taint nodes --all node-role.kubernetes.io/control-plane- kubectl taint nodes --all node-role.kubernetes.io/master- ``` ### 5. 安装网络插件(flannel) ```bash kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml ``` ### 6. 验证 ```bash kubectl get nodes # 应该显示节点状态为Ready kubectl get pods --all-namespaces # 查看所有pod是否正常运行 ``` 注意:如果初始化过程中出现问题,可以使用`kubeadm reset`重置。 引用说明:以上步骤参考了引用[1]和[2]的环境准备和安装步骤,并参考引用[4]安装了flannel网络插件。同时,根据单节点需要移除了master节点的污点。 §§相关问题§§ 1.Kubernetes单节点集群中,如何部署一个简单的Nginx应用? 2. 如何升级Kubernetes单节点集群的版本? 3. 在Ubuntu 22.04上使用minikube搭建单节点Kubernetes集群的步骤是什么? </think>### 在Ubuntu 22.04上搭建Kubernetes单机版详细步骤 #### 1. **环境准备** ```bash # 关闭swap sudo swapoff -a sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab # 配置内核参数 cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf overlay br_netfilter EOF sudo modprobe overlay sudo modprobe br_netfilter cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf net.bridge.bridge-nf-call-iptables = 1 net.bridge.bridge-nf-call-ip6tables = 1 net.ipv4.ip_forward = 1 EOF sudo sysctl --system # 设置主机名 sudo hostnamectl set-hostname k8s-single ``` #### 2. **安装容器运行时(containerd)** ```bash # 安装依赖 sudo apt-get update sudo apt-get install -y ca-certificates curl gnupg # 添加Docker仓库 sudo mkdir -m 0755 -p /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null # 安装containerd sudo apt-get update sudo apt-get install -y containerd.io # 配置containerd sudo mkdir -p /etc/containerd containerd config default | sudo tee /etc/containerd/config.toml sudo sed -i 's/SystemdCgroup = false/SystemdCgroup = true/g' /etc/containerd/config.toml sudo systemctl restart containerd ``` #### 3. **安装Kubernetes组件** ```bash # 添加Kubernetes仓库 sudo apt-get install -y apt-transport-https ca-certificates curl curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.28/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg echo 'deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.28/deb/ /' | sudo tee /etc/apt/sources.list.d/kubernetes.list # 安装kubeadm/kubelet/kubectl(指定1.28版本) sudo apt-get update sudo apt-get install -y kubelet=1.28.7-1.1 kubeadm=1.28.7-1.1 kubectl=1.28.7-1.1 sudo apt-mark hold kubelet kubeadm kubectl ``` #### 4. **初始化单节点集群** ```bash # 初始化控制平面(单节点模式) sudo kubeadm init \ --pod-network-cidr=10.244.0.0/16 \ --apiserver-advertise-address=127.0.0.1 \ --control-plane-endpoint=127.0.0.1 \ --ignore-preflight-errors=Swap # 配置kubectl mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config ``` #### 5. **安装网络插件(Flannel)** ```bash kubectl apply -f https://raw.githubusercontent.com/flannel-io/flannel/master/Documentation/kube-flannel.yml ``` #### 6. **解除Master调度限制(单节点必需)** ```bash kubectl taint nodes --all node-role.kubernetes.io/control-plane- ``` #### 7. **验证安装** ```bash kubectl get nodes # 应显示: # NAME STATUS ROLES AGE VERSION # k8s-single Ready control-plane 5m v1.28.7 kubectl get pods -A # 所有CoreDNS和flannel Pod应为Running状态 ``` ### 关键说明 1. **容器运行时**:Kubernetes 1.24+不再支持Docker,必须使用containerd或CRI-O[^2] 2. **网络配置**:`--pod-network-cidr=10.244.0.0/16`需匹配Flannel默认网段[^4] 3. **单节点优化**:解除污点允许在Master节点调度Pod 4. **版本选择**:使用较新的1.28版本(2023年Q3稳定版) ### 测试部署 ```bash kubectl create deployment nginx --image=nginx kubectl expose deployment nginx --port=80 kubectl get svc,pods ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

xiegwei

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

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

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

打赏作者

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

抵扣说明:

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

余额充值