From 2663c19414da81f6b35ab1c8d8f419404a5fa9e8 Mon Sep 17 00:00:00 2001 From: song Date: Sat, 14 May 2022 17:51:16 +0800 Subject: [PATCH] [zh] sync migrating-from-dockershim doc Signed-off-by: song --- .../migrating-from-dockershim/_index.md | 50 ++++- ...k-if-dockershim-deprecation-affects-you.md | 185 ------------------ .../find-out-runtime-you-use.md | 105 +++++++++- 3 files changed, 153 insertions(+), 187 deletions(-) delete mode 100644 content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/check-if-dockershim-deprecation-affects-you.md diff --git a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/_index.md b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/_index.md index cdeaed150c..8b55a149c0 100644 --- a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/_index.md +++ b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/_index.md @@ -2,6 +2,7 @@ title: "从 dockershim 迁移" weight: 10 content_type: task +no_list: true --- +Dockershim 在 Kubernetes v1.24 版本已经被移除。 +如果你集群内是通过 dockershim 使用 Docker 作为容器运行时,并希望 Kubernetes 升级到 v1.24, +建议你迁移到其他容器运行时或使用其他方法以获得 Docker 引擎支持。 + + +你的集群中可以有不止一种类型的节点,尽管这不是常见的情况。 + +下面这些任务可以帮助你完成迁移: + +* [检查弃用 Dockershim 对你的影响](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/check-if-dockershim-deprecation-affects-you/) +* [dockershim 迁移](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/) +* [从 dockershim 迁移遥测和安全代理](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/migrating-telemetry-and-security-agents/) + + +## 下一步 + +* 查看[容器运行时](/zh/docs/setup/production-environment/container-runtimes/)了解可选的容器运行时。 +* [GitHub 问题](https://github.com/kubernetes/kubernetes/issues/106917)跟踪有关 dockershim 的弃用和删除的讨论。 +* 如果你发现与 dockershim 迁移相关的缺陷或其他技术问题, + 可以在 Kubernetes 项目[报告问题](https://github.com/kubernetes/kubernetes/issues/new/choose)。 + \ No newline at end of file diff --git a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/check-if-dockershim-deprecation-affects-you.md b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/check-if-dockershim-deprecation-affects-you.md deleted file mode 100644 index 96132ad465..0000000000 --- a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/check-if-dockershim-deprecation-affects-you.md +++ /dev/null @@ -1,185 +0,0 @@ ---- -title: 检查弃用 Dockershim 对你的影响 -content_type: task -weight: 20 ---- - - - - - -Kubernetes 的 `dockershim` 组件使得你可以把 Docker 用作 Kubernetes 的 -{{< glossary_tooltip text="容器运行时" term_id="container-runtime" >}}。 -在 Kubernetes v1.20 版本中,内建组件 `dockershim` 被[弃用](/zh/blog/2020/12/08/kubernetes-1-20-release-announcement/#dockershim-deprecation)。 - - - -本页讲解你的集群把 Docker 用作容器运行时的运作机制, -并提供使用 `dockershim` 时,它所扮演角色的详细信息, -继而展示了一组操作,可用来检查弃用 `dockershim` 对你的工作负载是否有影响。 - - -## 检查你的应用是否依赖于 Docker {#find-docker-dependencies} - - -即使你是通过 Docker 创建的应用容器,也不妨碍你在其他任何容器运行时上运行这些容器。 -这种使用 Docker 的方式并不构成对 Docker 作为一个容器运行时的依赖。 - - -当用了别的容器运行时之后,Docker 命令可能不工作,或者产生意外的输出。 -下面是判定你是否依赖于 Docker 的方法。 - - -1. 确认没有特权 Pod 执行 Docker 命令(如 `docker ps`)、重新启动 Docker - 服务(如 `systemctl restart docker.service`)或修改 Docker 配置文件 - `/etc/docker/daemon.json`。 -2. 检查 Docker 配置文件(如 `/etc/docker/daemon.json`)中容器镜像仓库的镜像(mirror)站点设置。 - 这些配置通常需要针对不同容器运行时来重新设置。 -3. 检查确保在 Kubernetes 基础设施之外的节点上运行的脚本和应用程序没有执行 Docker 命令。 - 可能的情况如: - - SSH 到节点排查故障; - - 节点启动脚本; - - 直接安装在节点上的监控和安全代理。 -4. 检查执行上述特权操作的第三方工具。详细操作请参考 - [从 dockershim 迁移遥测和安全代理](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/migrating-telemetry-and-security-agents)。 -5. 确认没有对 dockershim 行为的间接依赖。这是一种极端情况,不太可能影响你的应用。 - 一些工具很可能被配置为使用了 Docker 特性,比如,基于特定指标发警报, - 或者在故障排查指令的一个环节中搜索特定的日志信息。 - 如果你有此类配置的工具,需要在迁移之前,在测试集群上测试这类行为。 - - -## Docker 依赖详解 {#role-of-dockershim} - - -[容器运行时](/zh/docs/concepts/containers/#container-runtimes)是一个软件,用来运行组成 Kubernetes Pod 的容器。 -Kubernetes 负责编排和调度 Pod;在每一个节点上,{{< glossary_tooltip text="kubelet" term_id="kubelet" >}} -使用抽象的容器运行时接口,所以你可以任意选用兼容的容器运行时。 - - -在早期版本中,Kubernetes 提供的兼容性支持一个容器运行时:Docker。 -在 Kubernetes 发展历史中,集群运营人员希望采用更多的容器运行时。 -于是 CRI 被设计出来满足这类灵活性需要 - 而 kubelet 亦开始支持 CRI。 -然而,因为 Docker 在 CRI 规范创建之前就已经存在,Kubernetes 就创建了一个适配器组件 `dockershim`。 -dockershim 适配器允许 kubelet 与 Docker 交互,就好像 Docker 是一个 CRI 兼容的运行时一样。 - - -你可以阅读博文 -[Kubernetes 正式支持集成 Containerd](/zh/blog/2018/05/24/kubernetes-containerd-integration-goes-ga/)。 - - -![Dockershim 和 Containerd CRI 的实现对比图](/images/blog/2018-05-24-kubernetes-containerd-integration-goes-ga/cri-containerd.png) - - -切换到容器运行时 Containerd 可以消除掉中间环节。 -所有相同的容器都可由 Containerd 这类容器运行时来运行。 -但是现在,由于直接用容器运行时调度容器,它们对 Docker 是不可见的。 -因此,你以前用来检查这些容器的 Docker 工具或漂亮的 UI 都不再可用。 - - -你不能再使用 `docker ps` 或 `docker inspect` 命令来获取容器信息。 -由于你不能列出容器,因此你不能获取日志、停止容器,甚至不能通过 `docker exec` 在容器中执行命令。 - - -{{< note >}} -如果你在用 Kubernetes 运行工作负载,最好通过 Kubernetes API 停止容器, -而不是通过容器运行时来停止它们 -(此建议适用于所有容器运行时,不仅仅是针对 Docker)。 -{{< /note >}} - - -你仍然可以下载镜像,或者用 `docker build` 命令创建它们。 -但用 Docker 创建、下载的镜像,对于容器运行时和 Kubernetes,均不可见。 -为了在 Kubernetes 中使用,需要把镜像推送(push)到某镜像仓库。 - - -## {{% heading "whatsnext" %}} - -- 阅读[从 dockershim 迁移](/zh/docs/tasks/administer-cluster/migrating-from-dockershim/)以了解你的下一步工作 -- 阅读[dockershim 弃用常见问题解答](/zh/blog/2020/12/02/dockershim-faq/)文章了解更多信息。 \ No newline at end of file diff --git a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/find-out-runtime-you-use.md b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/find-out-runtime-you-use.md index 7a6f3c8df9..5c11ccc645 100644 --- a/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/find-out-runtime-you-use.md +++ b/content/zh/docs/tasks/administer-cluster/migrating-from-dockershim/find-out-runtime-you-use.md @@ -55,16 +55,34 @@ kubectl get nodes -o wide 输出如下面所示。`CONTAINER-RUNTIME` 列给出容器运行时及其版本。 +对于 Docker Engine,输出类似于: ```none -# For dockershim NAME STATUS VERSION CONTAINER-RUNTIME node-1 Ready v1.16.15 docker://19.3.1 node-2 Ready v1.16.15 docker://19.3.1 node-3 Ready v1.16.15 docker://19.3.1 ``` + + +如果你的容器运行时显示为 Docker Engine,你仍然可能不会被 1.24 中 dockershim 的移除所影响。 +通过[检查运行时端点](#which-endpoint),可以查看你是否在使用 dockershim。 +如果你没有使用 dockershim,你就不会被影响。 +看下是否是使用的 dockershim,如何是 dockershim 则会受到在 Kubernetes 1.24 中移除 dockershim 的影响。 +反之则不会受到影响。 + +对于 containerd,输出类似于这样: ```none # For containerd @@ -81,3 +99,88 @@ on [Container Runtimes](/docs/setup/production-environment/container-runtimes/) 你可以在[容器运行时](/zh/docs/setup/production-environment/container-runtimes/) 页面找到与容器运行时相关的更多信息。 + +## 检查当前使用的运行时端点 {#which-endpoint} + + + +容器运行时使用 Unix Socket 与 kubelet 通信,这一通信使用基于 gRPC 框架的 +[CRI 协议](/zh/docs/concepts/architecture/cri/)。kubelet 扮演客户端,运行时扮演服务器端。 +在某些情况下,你可能想知道你的节点使用的是哪个 socket。 +如若集群是 Kubernetes 1.24 及以后的版本, +或许你想知道当前运行时是否是使用 dockershim 的 Docker Engine。 + + + +{{}} +如果你的节点在通过 `cri-dockerd` 使用 Docker Engine, +那么集群不会受到 Kubernetes 移除 dockershim 的影响。 +{{}} + + +可以通过检查 kubelet 的参数得知当前使用的是哪个 socket。 + + +1. 查看 kubelet 进程的启动命令 + + ``` + tr \\0 ' ' < /proc/"$(pgrep kubelet)"/cmdline + ``` + 如有节点上没有 `tr` 或者 `pgrep`,就需要手动检查 kubelet 的启动命令 + + +2. 在命令的输出中,查找 `--container-runtime` 和 `--container-runtime-endpoint` 标志。 + + * 如果 Kubernetes 集群版本是 v1.23 或者更早的版本,并且这两个参数不存在, + 或者 `container-runtime` 标志值不是 `remote`,则你在通过 dockershim 套接字使用 + Docker Engine。 + 或者如果集群使用的 Docker engine 和 dockershim socket,则输出结果中 `--container-runtime` 不是 `remote`, + * 如果设置了 `--container-runtime-endpoint` 参数,查看套接字名称即可得知当前使用的运行时。 + 如若套接字 `unix:///run/containerd/containerd.sock` 是 containerd 的端点。 + + +如果想将节点上的容器运行时从 Docker Engine 切换成 containerd,可在 +[Docker Engine 迁移到 containerd](zh/docs/tasks/administer-cluster/migrating-from-dockershim/change-runtime-containerd/) +找到更多信息。或者,如果你想在 Kubernetes v1.24 及以后的版本仍使用 Docker Engine, +可以安装 CRI 兼容的适配器实现,如 [`cri-dockerd`](https://github.com/Mirantis/cri-dockerd)。 +[`cri-dockerd`](https://github.com/Mirantis/cri-dockerd)。 \ No newline at end of file