开发容器 FAQ
本文档包含了一些在使用 Dev Containers 扩展在不同环境中进行设置和运行时遇到的常见问题。
“开发容器定义”是否定义了应用程序的部署方式?
否。开发容器定义了一个在准备部署之前用于开发应用程序的环境。虽然部署容器和开发容器可能看起来相似,但您可能不希望在部署映像中包含开发过程中使用的工具。
“devcontainers/templates 仓库”包含了一些常见开发环境的开发容器定义。如果您更喜欢使用替代的容器构建或部署工作流,也可以在不设置开发容器定义的情况下连接到正在运行的容器。
“开发容器定义”是否定义了应用程序的构建方式?比如 Buildpacks?
否。Buildpacks 的概念侧重于通过一系列定义的步骤来获取源代码并生成可部署的容器映像。开发容器是您在准备构建之前开发应用程序的环境。因此,它们是互补的概念。
尝试将本地文件系统挂载到容器时出现错误
右键单击 Docker 任务栏图标。在 Windows 上,选择“设置”菜单项,然后选择“资源 > 文件共享”,并勾选包含源代码的驱动器。在 macOS 上,选择“偏好设置”菜单项,然后选择“资源 > 文件共享”,并确保包含源代码的文件夹位于列表中指定的文件路径下。
有关解决常见的 Docker for Windows 问题的解决方案,请参阅Docker Desktop for Windows 技巧。
出现关于缺少库或依赖项的错误
某些扩展依赖于特定 Docker 映像中未找到的库。例如,Visual Studio Live Share 需要安装系统级依赖项,这些依赖项在其文档中列出。这些依赖项的需求可能取决于您的 Docker 映像使用的操作系统(例如,特定的 Linux 发行版)。您可能需要在 Docker 构建过程中安装这些依赖项,方法是将必要的命令添加到您的 Dockerfile 中。搜索特定扩展的文档以检查依赖项,并参阅安装其他软件以获得解决问题的帮助。
可以同时连接到多个容器吗?
一个 VS Code 窗口目前只能连接到一个窗口,但您可以打开一个新的窗口并连接到已在运行的容器,或者使用包含多个 devcontainer.json 文件的通用 Docker Compose 文件来稍微自动化此过程。
可以处理远程主机上的容器吗?
是的,请参阅关于在远程 SSH 主机上打开文件夹或在容器中打开远程隧道主机上的文件夹的部分以获取信息。
在容器内工作时,如何将容器映像构建或部署到我的本地 Docker / Kubernetes 安装中?
您可以通过转发 Docker 套接字并在容器中安装 Docker CLI(以及 Kubernetes 的 kubectl)来构建映像和部署容器。有关详细信息,请参阅Docker outside of Docker、Docker outside of Docker Compose 和Kubernetes-Helm 开发容器定义。
在容器中运行 VS Code Server 时,有哪些连接要求?
安装 VS Code Server 要求您的本地计算机具有到以下地址的出站 HTTPS(端口 443)连接:
update.code.visualstudio.comvscode.download.prss.microsoft.com
Dev Containers 扩展将会在连接后在本地下载 VS Code Server 并将其复制到容器中。
您可以使用“扩展:从 VSIX 安装…”命令在没有互联网连接的情况下手动安装扩展,但如果您使用扩展面板或 devcontainer.json 来安装扩展,则您的本地计算机和 VS Code Server 需要到以下地址的出站 HTTPS(端口 443)访问:
marketplace.visualstudio.com*.gallerycdn.vsassets.io(Azure CDN)
最后,一些扩展(如 C#)从 download.microsoft.com 或 download.visualstudio.microsoft.com 下载次要依赖项。其他扩展(如 Visual Studio Live Share)可能有额外的连接要求。如果你遇到问题,请查阅扩展的文档以获取详细信息。
VS Code Server 在容器内的随机端口上运行,VS Code 本身使用 docker exec 通过 Docker 配置的通信通道与之通信。
作为扩展作者,我需要做些什么来确保我的扩展正常工作?
VS Code 扩展 API 隐藏了远程运行的大部分实现细节,因此许多扩展在开发容器中无需任何修改即可正常工作。但是,我们建议您在开发容器中测试您的扩展,以确保其所有功能都能按预期运行。有关详细信息,请参阅关于支持远程开发的文章。
还有哪些其他资源可以解答我的问题?
以下文章可能有助于解答您的问题:
- 高级容器配置 或 技巧与窍门
- Dockerfile 参考
- Docker Compose 文件参考
- Docker Desktop for Windows 故障排除指南和常见问题解答
- Docker Desktop for Mac 故障排除指南和常见问题解答
可以在 VS Code 之外使用开发容器吗?
随着生产工作负载容器化的普及,开发容器已变得可用于 VS Code 以外的场景。我们正在创建开发容器规范,以使任何工具中的任何人都能配置一致的开发环境。它试图找到方法来丰富现有的格式,增加常见的开发特定设置、工具和配置,同时仍提供简化的、未经编排的单容器选项——这样它们就可以用作编码环境或用于持续集成和测试。
您可以在containers.dev 上了解更多信息并查阅规范,您也可以在 GitHub 上的devcontainers/spec 仓库中查阅活动提案并为规范做出贡献。