我有一个非常具体的 Docker/Windows 问题,有非常具体的限制。我希望我能找到一个确凿的答案(“不,它不能完成”,或者“可以通过这些可重复的步骤来完成”。)
我需要在 Windows 上安装 Docker 的社区版(不是许可的 Docker Desktop,而是“原始”CLI)。
这可以使用随附的 DockerCli.exe 程序在(许可的)Docker Desktop 中完成。例如:
PS> .\DockerCli.exe -SwitchLinuxEngine
需要从使用 Windows 容器切换到使用 Linux 容器(以便让 dockerd pull 并运行一些基于 Alpine 的自定义/旧版映像。)如果没有这个,Windows 上的 Docker 将抱怨如下:
2020-09-18T03:30:24.0943834Z image operating system "linux" cannot be used on this platform
使用 Docker Desktop,这没有问题(只需使用 DockerCli.exe 获取守护程序来切换容器策略。)
但是现在 Docker Desktop 需要许可证,这不是一个选项(或者不是首选选项。)
不幸的是,我找不到仅使用普通 docker 切换容器策略的方法(通过直接发布或通过诸如 Scoop 之类的工具安装。)
所以,我非常具体的问题是:
这可以在 Windows 上使用简单的 docker 二进制文件完成,而不依赖 Docker Desktop、WSL2 等吗?也许通过使用 PowerShell 来调整系统,或者使用其他一些未经许可的开源 CLI 来实现这一点?
我正在寻找是/否的答案(如果是,希望有可重复的说明。)
如果无法完成,只要我能记录下来,我就可以接受。
请注意我提出这个问题的严格背景/约束。
谢谢,周末愉快。
PS。
我不想争论 WSL2 是否好,或者我为什么不考虑将它作为一个选项。WSL2 没有任何问题,但是存在一些操作限制,使 WSL2 对于非常具体的业务案例不太理想(我不打算在这里讨论)。
谢谢。
不,这是不可能的。不是没有虚拟机。
要了解原因,首先需要了解 Linux 上的容器是如何工作的:通过利用内核功能在某些方面将进程树与主机系统隔离开来。通常,容器有自己的:
localhost
)借助 WSL,您现在可以在 Windows 上运行 Linux 二进制文件。但是,WSL 1 不使用 Linux 内核,因此不支持 Linux 命名空间。WSL 1 无法运行 Docker 容器。
Docker Desktop 利用虚拟机在“Windows”上运行 Linux 容器。它支持两种操作模式:Hyper-V 和 WSL 2。Hyper-V 是 Docker Desktop 的原始工作方式,但在 Windows Home 版本中不可用。WSL 2 在底层构建于 Hyper-V 平台之上。它在家庭版中可用。与最初的 Docker Desktop Hyper-V VM 一样,它运行真正的 Linux 内核。
当您在 Docker Desktop 上“切换到 Linux”时,您将切换到运行 Linux 的虚拟机。
您不能在 Windows 上运行 Linux 容器。Linux 容器仅在 Linux 上运行。
您可以将 Docker Desktop 替换为完全开源的软件,并获得(通过一些额外的工作)相同的 CLI 体验。但是,VM 是绝对需要的。