From b6b55abeb91b8d0bbe6bb014519b23a827c85e06 Mon Sep 17 00:00:00 2001 From: Qiming Teng Date: Sun, 29 May 2022 16:41:22 +0800 Subject: [PATCH] [zh] Translate migrate-dockershim-dockerd page --- .../migrate-dockershim-dockerd.md | 233 ++++++++++++++++++ 1 file changed, 233 insertions(+) create mode 100644 content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/migrate-dockershim-dockerd.md diff --git a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/migrate-dockershim-dockerd.md b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/migrate-dockershim-dockerd.md new file mode 100644 index 0000000000..43a80ef2df --- /dev/null +++ b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/migrate-dockershim-dockerd.md @@ -0,0 +1,233 @@ +--- +title: 将 Docker Engine 节点从 dockershim 迁移到 cri-dockerd +weight: 9 +content_type: task +--- + + + +{{% thirdparty-content %}} + + +本页面为你展示如何迁移你的 Docker Engine 节点,使之使用 `cri-dockerd` 而不是 dockershim。 +在以下场景中,你可以遵从这里的步骤执行操作: + +* 你期望不再使用 dockershim,但仍然使用 Docker Engine 来在 Kubernetes 中运行容器。 +* 你希望升级到 Kubernetes v{{< skew currentVersion >}} 且你的现有集群依赖于 dockershim, + 因此你必须放弃 dockershim,而 `cri-dockerd` 是你的一种选项。 + +要进一步了解 dockershim 的移除,请阅读 [FAQ 页面](/zh/dockershim)。 + + +## cri-dockerd 是什么? {#what-is-cri-dockerd} + +在 Kubernetes v1.24 及更早版本中,你可以在 Kubernetes 中使用 Docker Engine, +依赖于一个称作 _dockershim_ 的内置 Kubernetes 组件。 +dockershim 组件在 Kubernetes v1.24 发行版本中已被移除;不过,一种来自第三方的替代品, +`cri-dockerd` 是可供使用的。`cri-dockerd` 适配器允许你通过 +{{}} +来使用 Docker Engine。 + +{{}} + +如果你已经在使用 `cri-dockerd`,那么你不会被 dockershim 的移除影响到。 +在开始之前,[检查你的节点是否在使用 dockershim](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/find-out-runtime-you-use/)。 +{{}} + + +如果你想要迁移到 `cri-dockerd` 以便继续使用 Docker Engine 作为你的容器运行时, +你需要在所有被影响的节点上执行以下操作: + +1. 安装 `cri-dockerd`; +1. 隔离(Cordon)并腾空(Drain)该节点; +1. 配置 kubelet 使用 `cri-dockerd`; +1. 重新启动 kubelet; +1. 验证节点处于健康状态。 + + +首先在非关键节点上测试这一迁移过程。 + +你应该针对所有希望迁移到 `cri-dockerd` 的节点执行以下步骤。 + +## {{% heading "prerequisites" %}} + + +* 安装了 [`cri-dockerd`](https://github.com/mirantis/cri-dockerd#build-and-install) + 并且该服务已经在各节点上启动; +* 一个[网络插件](/zh/docs/concepts/extend-kubernetes/compute-storage-net/network-plugins/)。 + + +## 隔离并腾空节点 {#cordon-and-drain-the-node} + +1. 隔离节点,阻止新的 Pod 被调度到节点上: + + ```shell + kubectl cordon + ``` + + 将 `` 替换为节点名称。 + + +2. 腾空节点以安全地逐出所有运行中的 Pod: + + ```shell + kubectl drain --ignore-daemonsets + ``` + + +## 配置 kubelet 使用 cri-dockerd {#configure-the-kubelet-to-use-cri-dockerd} + +下面的步骤适用于用 kubeadm 工具安装的集群。如果你使用不同的工具, +你需要使用针对该工具的配置指令来修改 kubelet。 + + +1. 在每个被影响的节点上,打开 `/var/lib/kubelet/kubeadm-flags.env` 文件; +1. 将 `--container-runtime-endpoint` 标志,将其设置为 `unix:///var/run/cri-dockerd.sock`。 + + +kubeadm 工具将节点上的套接字存储为控制面上 `Node` 对象的注解。 +要为每个被影响的节点更改此套接字: + + +1. 编辑 `Node` 对象的 YAML 表示: + + ```shell + KUBECONFIG=/path/to/admin.conf kubectl edit no + ``` + + 根据下面的说明执行替换: + + * `/path/to/admin.conf`:指向 kubectl 配置文件 `admin.conf` 的路径; + * ``:你要修改的节点的名称。 + +1. 将 `kubeadm.alpha.kubernetes.io/cri-socket` 标志从 + `/var/run/dockershim.sock` 更改为 `unix:///var/run/cri-dockerd.sock`; +1. 保存所作更改。保存时,`Node` 对象被更新 + + + +## 重启 kubelet {#restart-the-kubelet} + +```shell +systemctl restart kubelet +``` + + +## 验证节点处于健康状态 {#verify-that-the-node-is-healthy} + +要检查节点是否在使用 `cri-dockerd` 端点, +按照[找出你所使用的运行时](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/find-out-runtime-you-use/)页面所给的指令操作。 +kubelet 的 `--container-runtime-endpoint` 标志取值应该是 `unix:///var/run/cri-dockerd.sock`。 + + +## 解除节点隔离 {#uncordon-the-node} + +```shell +kubectl uncordon +``` + +## {{% heading "whatsnext" %}} + + +* 阅读 [dockershim 移除常见问题](/zh/dockershim)。 +* [了解如何从基于 dockershim 的 Docker Engine 迁移到 containerd](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/change-runtime-containerd/)。 +