聊聊kubernetes1.20用containerd替換docker(shim)的問(wèn)題
kubernetes 1.20 要去掉對(duì) Docker的支持,具體看這里,本篇文章介紹用 containerd 替換 docker,從work節(jié)點(diǎn)開(kāi)始,然后才到master節(jié)點(diǎn)。
首先查看集群
[root@node1 ~]# kubectl get node NAME STATUS ROLES AGE VERSION k8s-master Ready control-plane,master 101d v1.20.1 k8s-worker-01 Ready <none> 101d v1.20.1 k8s-worker-02 Ready <none> 2d22h v1.20.1
ssh連接到 k8s-worker-01
A. 在work節(jié)點(diǎn)上替換
- 從服務(wù)中刪除一個(gè)節(jié)點(diǎn)
使用 kubectl drain 從節(jié)點(diǎn)安全地逐出所有 Pods。 安全的驅(qū)逐過(guò)程允許 Pod 的容器 體面地終止, 并確保滿(mǎn)足指定的 PodDisruptionBudgets。
kubectl drain k8s-worker-01 --ignore-daemonsets --delete-emptydir-data
- 停止 kubelet
sudo systemctl stop kubelet
- 卸載docker
sudo apt remove docker-ce docker-ce-cli sudo apt autoremove
- 啟用containerd的前置條件
為了containerd能和kubernetes正常運(yùn)行,需加載overlay和br_netfilter兩個(gè)模塊。
下面創(chuàng)建containerd.conf,在啟動(dòng)時(shí)加載這些模塊
cat <<EOF | sudo tee /etc/modules-load.d/containerd.conf overlay br_netfilter EOF
下一條命令將加載所需的模塊
sudo modprobe overlay sudo modprobe br_netfilter
創(chuàng)建一個(gè)文件,用于系統(tǒng)啟動(dòng)時(shí)設(shè)置其他參數(shù)
cat <<EOF | sudo tee /etc/sysctl.d/99-kubernetes-cri.conf net.bridge.bridge-nf-call-iptables = 1 net.ipv4.ip_forward = 1 net.bridge.bridge-nf-call-ip6tables = 1 EOF
應(yīng)用一下設(shè)置
sudo sysctl --system
安裝以下軟件包以允許apt通過(guò)HTTPS使用倉(cāng)庫(kù)。
sudo apt-get update && sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common
添加Docker官方GPG key,為啥要這樣呢?因?yàn)閏ontainerd 也需要使用Docker鏡像倉(cāng)庫(kù)去搜索鏡像。
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key --keyring /etc/apt/trusted.gpg.d/docker.gpg add -
添加docker源
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu focal stable"
- 安裝containerd
sudo apt-get update && sudo apt-get install -y containerd.io
- 配置containerd
sudo mkdir -p /etc/containerd sudo containerd config default | sudo tee /etc/containerd/config.toml
- 使用systemd cgroup driver
sudo vim /etc/containerd/config.toml
找到下面這行,添加SystemdCgroup = true,例子如下:
[plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc]
...
[plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc.options]
SystemdCgroup = true
- 啟動(dòng)服務(wù)
sudo systemctl enable containerd sudo systemctl start containerd sudo systemctl status containerd
- 配置Kubelet以使用containerd
修改 /var/lib/kubelet/kubeadm-flags.env 文件,改為如下
KUBELET_KUBEADM_ARGS="--container-runtime=remote --container-runtime-endpoint=/run/containerd/containerd.sock"
- 啟動(dòng)kubernetes
sudo systemctl daemon-reload sudo systemctl start kubelet
驗(yàn)證
[root@node1 ~]# kubectl get node NAME STATUS ROLES AGE VERSION k8s-master Ready control-plane,master 101d v1.20.1 k8s-worker-01 Ready,SchedulingDisabled <none> 101d v1.20.1 k8s-worker-02 Ready <none> 3d v1.20.1
如果一切正常,你剛剛操作的機(jī)器就會(huì)顯示Ready,SchedulingDisabled,如果顯示Not ready,你就要檢查是否嚴(yán)格按照我的步驟來(lái)操作的。
- 啟用調(diào)度
kubectl Uncordon k8s-worker-01
重新查看集群狀態(tài),會(huì)發(fā)現(xiàn)k8s-worker-01的 STATUS 已經(jīng)變成了 Ready,你可以對(duì)其他節(jié)點(diǎn)進(jìn)行操作了。
B. 在master節(jié)點(diǎn)上替換
- 停止master節(jié)點(diǎn)
由于master節(jié)點(diǎn)不能drain ,所以只能停止kubelet,work節(jié)點(diǎn)和pods會(huì)繼續(xù)運(yùn)行,但無(wú)法進(jìn)行管理。
sudo systemctl stop kubelet
執(zhí)行前面的 3-10 步驟
- 修改kubernetes配置文件
最后一步是從kubernetes修改配置文件。盡管此階段的主節(jié)點(diǎn)和工作節(jié)點(diǎn)已經(jīng)在使用containerd,但是還需要調(diào)整配置設(shè)置,否則在運(yùn)行kubeadm命令時(shí)會(huì)出錯(cuò)(例如,將kubernetes升級(jí)到新版本)
在master節(jié)點(diǎn)執(zhí)行
kubectl edit node k8s-master
將
kubeadm.alpha.kubernetes.io/cri-socket: /var/run/dockershim.sock
修改為
kubeadm.alpha.kubernetes.io/cri-socket: /run/containerd/containerd.sock
您可以運(yùn)行以下命令檢查kubeadm是否正常運(yùn)行。通過(guò)運(yùn)行以下命令,該命令將檢查集群是否可以升級(jí)。
sudo kubeadm upgrade plan

到此這篇關(guān)于kubernetes1.20用containerd替換docker(shim)的文章就介紹到這了,更多相關(guān)kubernetes替換docker內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于如何使用docker部署centos系統(tǒng)測(cè)試環(huán)境
這篇文章主要介紹了關(guān)于如何使用docker部署centos系統(tǒng)測(cè)試環(huán)境,Docker屬于操作系統(tǒng)虛擬化技術(shù),本文圖文講解部署過(guò)程,需要的朋友可以參考下2023-03-03
使用docker -v 和 Publish over SSH插件實(shí)現(xiàn)war包自動(dòng)部署到docker的操作步驟
這篇文章主要介紹了利用docker -v 和 Publish over SSH插件實(shí)現(xiàn)war包自動(dòng)部署到docker的操作步驟,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-01-01
Docker搭建NetBox的實(shí)現(xiàn)示例
NetBox是一個(gè)開(kāi)源的數(shù)據(jù)中心基礎(chǔ)設(shè)施管理和IP地址管理平臺(tái),本文主要介紹了Docker搭建NetBox的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-04-04
使用Docker部署 spring-boot maven應(yīng)用的方法
本篇文章主要介紹了使用Docker部署 spring-boot maven應(yīng)用的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
如何使用Docker Desktop進(jìn)行本地打包和推送
本文給大家介紹如何使用Docker Desktop進(jìn)行本地打包和推送,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-04-04
解決docker使用GDB,無(wú)法進(jìn)入斷點(diǎn)的問(wèn)題
這篇文章主要介紹了解決docker使用GDB,無(wú)法進(jìn)入斷點(diǎn)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
docker一鍵部署MySQL的實(shí)現(xiàn)示例
本文主要介紹了docker一鍵部署MySQL的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
Docker Machine遠(yuǎn)程部署Docker的方法
本篇文章主要介紹了Docker Machine遠(yuǎn)程部署Docker的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04

