云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1)

目录

一、理论

1.K8S集群升级

2.环境

3.升级策略

4.master1节点迁移容器运行时(docker → containerd)

5.master2节点迁移容器运行时(docker → containerd)

6.node1节点容器运行时迁移(docker → containerd)

7.升级集群计划(v1.23.14 →v1.24.1)

8.升级master1节点版本(v1.24.1)

9.升级master2节点版本(v1.24.1)

10.升级node1节点版本(v1.24.1)

11.验证集群(v1.24.1)

二、实验

1. 环境

2.master1节点迁移容器运行时(docker → containerd)

3.master2节点迁移容器运行时(docker → containerd)

4.node1节点迁移容器运行时(docker → containerd)

5.升级集群计划(v1.23.14 →v1.24.1)

6.升级master1节点版本(v1.24.1)

7.升级 master2节点版本(v1.24.1)

8.升级 node1节点版本(v1.24.1)

9.验证集群(v1.24.1)


一、理论

1.K8S集群升级

(1)概念

搭建K8S集群的方式有很多种,比如二进制,kubeadm,RKE(Rancher)等,K8S集群升级方式也各有千秋,目前准备使用kubeadm方式搭建的k8s集群升级方法。

需要注意的是,升级集群版本建议逐步升级,比如v1.21.1–>v1.22.1–>v1.23.1–>v1.24.1,不能跨度过大,否则会报错。

2.环境

(1)主机(容器运行时)

表1 主机(容器运行时)

主机架构当前容器运行时目标容器运行时IP
master1K8S master节点docker 20.10.6containerd 1.6.24192.168.204.180
master2K8S master节点docker20.10.6containerd 1.6.24192.168.204.181
node1K8S node节点docker20.10.6containerd 1.6.24192.168.204.182

(2)主机 (集群版本)

表2 主机(集群版本)

主机架构当前版本目标版本IP
master1K8S master节点v1.23.14v1.24.1192.168.204.180
master2K8S master节点v1.23.14v1.24.1192.168.204.181
node1K8S node节点v1.23.14v1.24.1192.168.204.182

3.升级策略

(1)升级策略1

先迁移容器运行时为containerd:

docker → containerd

(2)升级策略2

然后升级集群版本到v1.24.1:

v1.23.14 → v1.24.1

4.master1节点迁移容器运行时(docker → containerd)

(1)确定迁移容器运行时

可以看到目前的容器运行时是docker 20.10.6。

kubectl get nodes -owide #查看容器运行时

(2)迁移master1

kubectl drain master1--delete-emptydir-data--force --ignore-daemonsets #对k8s控制节点xianchaomaster1进行drain

(3)关闭并卸载Docker

systemctl disable docker--now #先启动dockeryum remove docker-ce docker-ce-cli -y #卸载

(4)安装并配置containerd

yum installcontainerd.io cri-tools-y # 安装crictl config runtime-endpoint unix:///var/run/containerd/containerd.sockcontainerd config default > /etc/containerd/config.toml#生成配置文件vim /etc/containerd/config.toml#使用vim编辑器打开,分别搜素mirrors、sandbox、SystemdCgroup并修改

(5)重启containerd服务

systemctl enable containerd; systemctl restart containerd# 重启systemctl status containerd# 查看服务状态

(6)配置并启动kubelet

vim /etc/sysconfig/kubelet #设置kubelet启动参数systemctl restart kubelet#重启kubelet服务

(7)对master节点进行uncordon

kubectl uncordon master1#解除维护

(8)验证

kubectl get nodes -owide#验证是否把容器运行时由docker迁移到containerd

5.master2节点迁移容器运行时(docker → containerd)

(1)确定迁移容器运行时

可以看到目前的容器运行时是docker 20.10.6。

kubectl get nodes -owide #查看容器运行时

(2)迁移master2

kubectl drain master2--delete-emptydir-data--force --ignore-daemonsets #对k8s控制节点xianchaomaster1进行drain

(3)关闭并卸载Docker

systemctl disable docker--now #先启动dockeryum remove docker-ce docker-ce-cli -y #卸载

(4)安装并配置containerd

yum installcontainerd.io cri-tools-y # 安装crictl config runtime-endpoint unix:///var/run/containerd/containerd.sockcontainerd config default > /etc/containerd/config.toml#生成配置文件vim /etc/containerd/config.toml#使用vim编辑器打开,分别搜素mirrors、sandbox、SystemdCgroup并修改

(5)重启containerd服务

systemctl enable containerd; systemctl restart containerd# 重启systemctl status containerd# 查看服务状态

(6)配置并启动kubelet

vim /etc/sysconfig/kubelet #设置kubelet启动参数systemctl restart kubelet#重启kubelet服务

(7)对master2节点进行uncordon

kubectl uncordon master2 #解除维护

(8)验证

kubectl get nodes -owide#验证是否把容器运行时由docker迁移到containerd

6.node1节点容器运行时迁移(docker → containerd)

(1)迁移node1节点

kubectl drain node1 --delete-emptydir-data--force --ignore-daemonsets #对k8s工作节点xianchaonode1进行drain

(2)关闭并卸载Docker

systemctl disable docker --now # 关闭yum remove docker-ce docker-ce-cli -y# 卸载

(3)安装并配置containerd

yum installcontainerd.io cri-tools-y#安装crictl config runtime-endpoint unix:///var/run/containerd/containerd.sock # 配置containerd config default > /etc/containerd/config.toml #生成配置文件vim /etc/containerd/config.toml #使用vim编辑器打开,分别搜素mirrors、sandbox、SystemdCgroup并修改

(4)重启containerd服务

 systemctl enable containerd; systemctl restart containerd # 重启

(5)配置并启动kubelet

vim /etc/sysconfig/kubelet #设置kubelet启动参数systemctl restart kubelet #重启kubelet服务kubectl get nodes -owide #查看pod

(6)对node1节点进行uncordon

 kubectl uncordon node1 #解除维护

(7)验证

kubectl get nodes -owide #验证是否把容器运行时由docker迁移到containerd

(8)查看

kubectl get pods -n kube-system#查看集群

7.升级集群计划(v1.23.14 →v1.24.1

(1)查看集群

 kubectl get nodes -owide# 查看集群版本

(2)修改master1节点kubelet参数

kubectl edit nodes master1 #修改 systemctl restart kubelet#重启

(3)修改master2节点kubelet参数

kubectl edit nodes master2 #修改 systemctl restart kubelet#重启

(4)修改node1节点kubelet参数

kubectl edit nodes node1 #修改 systemctl restart kubelet#重启

(5)确定升级版本

# 执行如下命令确定升级版本yum list --showduplicates kubeadm --disableexcludes=kubernetes

我的目标版本是1.24.1-0。

8.升级master1节点版本(v1.24.1)

(1)在k8s控制节点master1安装kubeadm1.24.1

yum install -y kubeadm-1.24.1-0 --disableexcludes=kubernetes

(2)腾空控制节点master1

kubectl drain master1--delete-emptydir-data--force --ignore-daemonsets

(3)升级控制节点master1各个组件

kubeadm upgrade apply v1.24.1

(4)升级kubectl和kubelet到1.24.1

yum install -y kubelet-1.24.1-0 kubectl-1.24.1-0 --disableexcludes=kubernetes

(5)修改kubelet参数

vim /var/lib/kubelet/kubeadm-flags.env

(6)重启kubelet

systemctl daemon-reload;systemctl restart kubelet

(7)解除master1的节点维护

 kubectl uncordon master1

(8)查看节点状态

kubectl get nodes

9.升级master2节点版本(v1.24.1)

(1)在k8s控制节点master1安装kubeadm1.24.1

yum install -y kubeadm-1.24.1-0 --disableexcludes=kubernetes

(2)腾空控制节点master1

kubectl drain master2--delete-emptydir-data--force --ignore-daemonsets

(3)升级控制节点master1各个组件

kubeadm upgrade apply v1.24.1

(4)升级kubectl和kubelet到1.24.1

yum install -y kubelet-1.24.1-0 kubectl-1.24.1-0 --disableexcludes=kubernetes

(5)修改kubelet参数

vim /var/lib/kubelet/kubeadm-flags.env

(6)重启kubelet

systemctl daemon-reload;systemctl restart kubelet

(7)解除master1的节点维护

 kubectl uncordon master2

(8)查看节点状态

kubectl get nodes

10.升级node1节点版本(v1.24.1)

(1)在k8s工作节点node1安装kubeadm1.24.1

yum install -y kubeadm-1.24.1-0 --disableexcludes=kubernetes

(2)腾空控制节点master1

kubectl drain node1--delete-emptydir-data--force --ignore-daemonsets

(3)升级node1上的kubelet

 kubeadm upgrade node

(4)修改kubelet参数

vim /var/lib/kubelet/kubeadm-flags.env

(5)升级kubelet和kubectl

yum install -y kubelet-1.24.1-0 kubectl-1.24.1-0 --disableexcludes=kubernetes

(6)重启kubelet

systemctl daemon-reload;systemctl restart kubelet

(7)解除node11的节点维护

 kubectl uncordon node1

11.验证集群(v1.24.1)

(1)验证集群状态是否正常

kubectl get nodes# 结果如下:[root@master1 ~]# kubectl get nodes

版本均已升级到 v1.24.1。

(2) 查看集群服务状态

kubectl get pods -n kube-system

二、实验

1. 环境

(1)主机(容器运行时)

表1 主机(容器运行时)

主机架构当前容器运行时目标容器运行时IP
master1K8S master节点docker 20.10.6containerd 1.6.24192.168.204.180
master2K8S master节点docker20.10.6containerd 1.6.24192.168.204.181
node1K8S node节点docker20.10.6containerd 1.6.24192.168.204.182

(2)主机 (集群版本)

表2 主机(集群版本)

主机架构当前版本目标版本IP
master1K8S master节点v1.23.14v1.24.14192.168.204.180
master2K8S master节点v1.24.14v1.24.14192.168.204.181
node1K8S node节点v1.24.14v1.24.14192.168.204.182

2.master1节点迁移容器运行时(docker → containerd)

(1)确定迁移容器运行时

可以看到目前的容器运行时是docker 20.10.6。图片[1] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)迁移master1图片[2] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(3)关闭并卸载Docker

先启动docker,再卸载

图片[3] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(4)安装并配置containerd

① 安装

图片[4] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

② 生成配置文件

图片[5] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

使用vim编辑器打开

图片[6] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

第一步:搜素mirrors,并修改(原来一行变三行)

修改前:

图片[7] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[8] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

第二步:搜索sandbox,并修改。

修改前:

图片[9] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[10] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL第三步:搜索SystemdCgroup,并修改。

修改前:

图片[11] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[12] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(5)重启containerd服务

重启

图片[13] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

②查看服务

图片[14] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(6)配置并启动kubelet

设置

图片[15] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

②修改

图片[16] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL重启kubelet服务

图片[17] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

这时查看pod,master1为SchedulingDisabled,容器运行时还未更新

图片[18] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(7)对master1节点进行uncordon图片[19] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(8)验证(此时master1可以调度)图片[20] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

3.master2节点迁移容器运行时(docker → containerd)

(1)迁移master2图片[21] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)关闭并卸载Docker

先启动

图片[22] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

卸载

图片[23] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(4)安装并配置containerd

安装

图片[24] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

② ⑩配置

图片[25] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

生成配置文件

图片[26] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

使用vim编辑器打开

图片[27] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

第一步:搜素mirrors,并修改(原来一行变三行)

图片[28] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

⑥第二步:搜索sandbox,并修改。

图片[29] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

⑦ ​​​​​​​​​​​​​​​​​​​​​第三步:搜索SystemdCgroup,并修改。

图片[30] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(5)重启containerd服务

重启

图片[31] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

② 查看服务

图片[32] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(6)配置并启动kubelet

设置

图片[33] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

② 修改

图片[34] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL
③ 重启

图片[35] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

这时查看pod,master2为SchedulingDisabled,容器运行时已更新

图片[36] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

​​​​​​​(7)对master2节点进行uncordon图片[37] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(8)验证(此时master2可以调度)图片[38] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

4.node1节点迁移容器运行时(docker → containerd)

(1)迁移node1节点​​​​​​​图片[39] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)关闭并卸载Docker

关闭并卸载

图片[40] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(3)安装并配置containerd

安装

图片[41] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

② 配置

图片[42] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

生成配置文件

图片[43] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

④ ​​​​​​​使用vim编辑器打开

图片[44] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

第一步:搜素mirrors,并修改(原来一行变三行)

图片[45] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

⑥​​​​​​​第二步:搜索sandbox,并修改。

图片[46] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

第三步:搜索SystemdCgroup,并修改。

图片[47] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(4)重启containerd服务

重启图片[48] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

② 查看服务

图片[49] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(5)配置并启动kubelet

设置

图片[50] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

这时查看pod,node1为SchedulingDisabled,容器运行时已更新

图片[51] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(6)对node节点进行uncordon图片[52] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(7)验证 (此时node1可以调度)图片[53] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(8)查看图片[54] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

5.升级集群计划v1.23.14 →v1.24.1

(1)确定升级版本

可以看到目前的版本是v1.23.14。​​​​​​​图片[55] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)修改节点kubelet参数(在runtime由docker迁移到containerd之后做)

①修改master1节点

图片[56] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改前:

图片[57] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[58] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

②重启

图片[59] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

③修改master2节点

图片[60] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改前:

图片[57] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[58] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

④重启

图片[63] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

⑤修改node1节点

图片[64] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改前:

图片[57] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[58] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

④重启

图片[67] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(3)确定升级计划

执行如下命令确定升级版本图片[68] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

图片[69] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

我的目标版本是1.24.1-0。

6.升级master1节点版本(v1.24.1)

(1)在k8s控制节点master1安装kubeadm1.24.1

图片[70] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)腾空控制节点master1

图片[71] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(3)升级控制节点master1各个组件

图片[72] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

成功

图片[73] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(4)升级kubectl和kubelet到1.24.1

图片[74] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(5)修改kubelet参数

图片[75] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改前:

图片[76] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[77] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(6)重启kubelet

图片[78] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(7)解除master1的节点维护

图片[79] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(8)查看节点状态(master1已升级为v1.24.1)

图片[80] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL图片[81] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

7.升级 master2节点版本(v1.24.1)

(1)在k8s控制节点master2安装kubeadm1.24.1

图片[82] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)腾空控制节点master2

图片[83] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(3)升级master2节点

图片[84] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

成功:

图片[85] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(4)升级kubectl和kubelet到1.24.1

图片[86] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(5)修改kubelet参数

图片[87] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改前:

图片[88] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[89] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(6)重启kubelet图片[90] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(7)查看节点状态(master1和master2都已升级为v1.24.1)

图片[91] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

8.升级 node1节点版本(v1.24.1)

(1)在node1节点上安装kubeadm 1.24.1

图片[92] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(2)腾空节点node1(驱逐node1的pod)

图片[93] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(3)升级node1上的kubelet

图片[94] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(4)修改kubelet变量

图片[95] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改前:

图片[96] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

修改后:

图片[97] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(5)升级kubelet和kubectl

图片[98] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

(6)解除对node1的保护

图片[99] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

9.验证集群(v1.24.1)

(1)验证集群状态是否正常

​​​​​​​​​​​​​​​​​​​​​图片[100] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

版本均已升级到 v1.24.1。

(2) 查看集群服务状态

图片[101] - 云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1) - MaxSSL

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享