将 Docker Engine 节点从 dockershim 迁移到 cri-dockerd

如果想继续使用Docker Engine作为容器运行时,可以将Docker Engine节点从dockershim迁移到cri-dockerd。cri-dockerd是Mirantis和Docker为Docker Engine维护一个替代适配器, 并在dockershim从Kubernetes移除后维护该适配器。如果想升级到 Kubernetes v1.30,并且现有集群依赖于 dockershim,那必须放弃 dockershim,使用cri-dockerd。

cri-dockerd 是什么?
在Kubernetes v1.24及更早版本中,可以在 Kubernetes 中使用Docker Engine, 依赖于一个称作 dockershim 的内置 Kubernetes 组件。 dockershim 组件在 Kubernetes v1.24 发行版本中已被移除;不过,cri-dockerd 是可供使用的。cri-dockerd 适配器允许通过容器运行时接口(Container Runtime Interface,CRI) 来使用 Docker Engine。

如果想要迁移到 cri-dockerd 以便继续使用 Docker Engine 作为容器运行时, 需要在所有被影响的节点上执行以下操作:

1)安装 cri-dockerd;
参考:

https://mirantis.github.io/cri-dockerd/usage/install/

下载release包进行安装

https://github.com/Mirantis/cri-dockerd/releases

2)隔离(Cordon)并腾空(Drain)该节点;
隔离节点,阻止新的 Pod 被调度到节点上:

kubectl cordon <NODE_NAME>

将 <NODE_NAME> 替换为节点名称。
腾空节点以安全地逐出所有运行中的 Pod:

kubectl drain <NODE_NAME> --ignore-daemonsets

3)配置 kubelet 使用 cri-dockerd;

下面的步骤适用于用 kubeadm 工具安装的集群。如果使用不同的工具, 需要使用针对该工具的配置指令来修改 kubelet。

  1. 在每个被影响的节点上,打开 /var/lib/kubelet/kubeadm-flags.env 文件;
  2. 将 --container-runtime-endpoint 标志,将其设置为 unix:///var/run/cri-dockerd.sock
  3. 将 --container-runtime 标志修改为 remote(在 Kubernetes v1.27 及更高版本中不可用)。

kubeadm 工具将节点上的套接字存储为控制面上 Node 对象的注解。 要为每个被影响的节点更改此套接字:

  1. 编辑 Node 对象的 YAML 表示:

    KUBECONFIG=/path/to/admin.conf kubectl edit no <NODE_NAME>
    

    根据下面的说明执行替换:

    • /path/to/admin.conf:指向 kubectl 配置文件 admin.conf 的路径;
    • <NODE_NAME>:你要修改的节点的名称。
  2. 将 kubeadm.alpha.kubernetes.io/cri-socket 标志从 /var/run/dockershim.sock 更改为 unix:///var/run/cri-dockerd.sock

  3. 保存所作更改。保存时,Node 对象被更新

4)重新启动 kubelet;

systemctl restart kubelet

5)验证节点处于健康状态。

要检查节点是否在使用 cri-dockerd 端点, 按照找出你所使用的运行时页面所给的指令操作。 kubelet 的 --container-runtime-endpoint 标志取值应该是 unix:///var/run/cri-dockerd.sock。

6)解除节点隔离

kubectl uncordon <NODE_NAME>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

明算科

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

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

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

打赏作者

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

抵扣说明:

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

余额充值