现已推出!阅读关于 11 月的新功能和修复。

减少 Docker 构建警告

以下是一些消除 Dockerfile 构建中可能出现的警告的技巧。

debconf:正在延迟软件包配置,因为未安装 apt-utils

通常可以安全地忽略此错误,并且很难完全消除。但是,在安装所需的软件包时,您可以通过将以下内容添加到 Dockerfile 中,将其减少为一个 stdout 消息

RUN apt-get update \
    && export DEBIAN_FRONTEND=noninteractive \
    && apt-get -y install --no-install-recommends apt-utils dialog 2>&1

警告:不应解析 apt-key 输出(stdout 不是终端)

此非关键警告告诉您不要解析 apt-key 的输出,因此只要您的脚本不解析,就没有任何问题。您可以安全地忽略它。

这会在 Dockerfile 中发生,因为 apt-key 命令不是从终端运行的。不幸的是,这个错误无法完全消除,但可以隐藏,除非 apt-key 命令返回非零退出代码(表示失败)。

例如

# (OUT=$(apt-key add - 2>&1) || echo $OUT) will only print the output with non-zero exit code is hit
curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | (OUT=$(apt-key add - 2>&1) || echo $OUT)

您还可以设置 APT_KEY_DONT_WARN_ON_DANGEROUS_USAGE 环境变量来抑制警告,但这看起来有点可怕,所以如果您使用它,请务必在 Dockerfile 中添加注释

# Suppress an apt-key warning about standard out not being a terminal. Use in this script is safe.
ENV APT_KEY_DONT_WARN_ON_DANGEROUS_USAGE=DontWarn

以红色显示的信息消息

某些 CLI 会将某些信息(如调试详细信息)输出到标准错误而不是标准输出。这些信息将以红色显示在 Visual Studio Code 的终端和输出日志中。

如果这些消息无害,您可以通过在命令末尾添加 2>&1 将命令的输出从标准错误管道传输到标准输出。

例如

RUN apt-get -y install --no-install-recommends apt-utils dialog 2>&1

如果命令失败,您仍然可以看到错误,但它们不会显示为红色。

避免使用 Docker 构建的镜像出现问题

鉴于 Dockerfile 和 Docker Compose 文件可以在没有 VS Code 或 devcontainer CLI 的情况下使用,您可能希望告知用户,如果它无法按预期工作,他们不应该尝试直接构建镜像。为了解决这个问题,您可以添加一个构建参数,该参数需要指定才能使工作正常进行。

例如,您可以将以下内容添加到 Dockerfile 中

ARG vscode
RUN if [[ -z "$devcontainercli" ]] ; then printf "\nERROR: This Dockerfile needs to be built with VS Code !" && exit 1; else printf "VS Code is detected: $devcontainercli"; fi

以及 devcontainer.json 中的以下内容

"build": {
      "dockerfile": "Dockerfile",
      "args": {
          // set devcontainer-cli arg for Dockerfile
          "devcontainercli": "true"
      },
    }

在 Docker Compose 案例中,您可以将此参数添加到单独的覆盖文件以扩展您的配置,该文件位于源代码树中与主要 Docker Compose 文件不同的位置。