在 Kubernetes v1.24 及更早版本中,你可以在 Kubernetes 中使用 Docker Engine, 依赖于一个称作 dockershim 的内置 Kubernetes 组件。
dockershim 组件在 Kubernetes v1.24 发行版本中已被移除;不过,一种来自第三方的替代品, cri-dockerd 是可供使用的。
cri-dockerd 适配器允许你通过 容器运行时接口(Container Runtime Interface,CRI) 来使用 Docker Engine。
意味着在k8s 1.24版本以上也能继续使用Docker Engine,只不过需要把原先的dockershim替换成cri-dockerd。
如果你想要迁移到 cri-dockerd 以便继续使用 Docker Engine 作为你的容器运行时, 你需要在所有被影响的节点上执行以下操作:
1.安装了 cri-dockerd 并且该服务已经在各节点上启动; 地址:https://github.com/mirantis/cri-dockerd#build-and-install
2. 一个网络插件。地址:https://kubernetes.io/zh/docs/concepts/extend-kubernetes/compute-storage-net/network-plugins/
# 隔离节点,阻止新的 Pod 被调度到节点上,将 <NODE_NAME> 替换为节点名称。
kubectl cordon <NODE_NAME>
腾空节点以安全地逐出所有运行中的 Pod:
kubectl drain <NODE_NAME> --ignore-daemonsets
下面的步骤适用于用 kubeadm 工具安装的集群。如果你使用不同的工具, 你需要使用针对该工具的配置指令来修改 kubelet。
1.在每个被影响的节点上,打开 /var/lib/kubelet/kubeadm-flags.env
文件;
2.将 --container-runtime-endpoin
t 标志,将其设置为 unix:///var/run/cri-dockerd.sock
。
kubeadm 工具将节点上的套接字存储为控制面上 Node 对象的注解。 要为每个被影响的节点更改此套接字:
1.编辑 Node 对象的 YAML 表示:
KUBECONFIG=/path/to/admin.conf kubectl edit no <NODE_NAME>
根据下面的说明执行替换:
2.将 kubeadm.alpha.kubernetes.io/cri-socket 标志从 /var/run/dockershim.sock
更改为 unix:///var/run/cri-dockerd.sock
;
3.保存所作更改。保存时,Node 对象被更新
systemctl restart kubelet
要检查节点是否在使用 cri-dockerd 端点, 按照找出你所使用的运行时页面所给的指令操作。 kubelet 的 --container-runtime-endpoint
标志取值应该是 unix:///var/run/cri-dockerd.sock
。
kubectl uncordon <NODE_NAME>
手机扫一扫
移动阅读更方便
你可能感兴趣的文章