Dockerfile ENV 使用指南

当使用 Dockerfile 进行构建镜像时,有时会须要设置容器内的环境变量。docker

ENV 指令的格式以下:post

ENV <key>=<value> ...

ENV 指令将环境变量 <key> 设置为值 <value>。这个值将在构建阶段的全部后续指令的环境中,
也能够被替换使用在其余指令中。
该值将被解释为其余环境变量,所以若是引号字符没有转义,它们将被删除。像命令行解析同样,引号和反斜杠能够用于在值中包含空格。ui

例如:命令行

ENV MY_NAME="John Doe"
ENV MY_DOG=Rex\ The\ Dog
ENV MY_CAT=fluffy

ENV 指令容许多个 <key>=<value> ... 变量同时设置,下面的例子将在生成的镜像中产生相同的结果:code

ENV MY_NAME="John Doe" MY_DOG=Rex\ The\ Dog \
    MY_CAT=fluffy

当使用生成的镜像运行容器时,使用 ENV 设置的环境变量将持久存在于容器内。
你可使用 docker inspect 查看这些值,并使用 docker run --env <key>=<value> 修改它们。get

环境变量持久性可能会致使意想不到的反作用。
例如,设置 ENV DEBIAN_FRONTEND=noninteractive 会改变 apt-get 的行为,并可能让使用镜像的用户感到困惑。dockerfile

若是只在构建过程当中须要环境变量,而不是在最终镜像中,请考虑为单个命令设置一个值:class

RUN DEBIAN_FRONTEND=noninteractive apt-get update && apt-get install -y ...

或者使用 ARG,它不会在最终镜像中持久存在:容器

ARG DEBIAN_FRONTEND=noninteractive
RUN apt-get update && apt-get install -y ...

替代语法变量

ENV 指令还容许另外一种语法 ENV <key> <value>,省略了中间的等号。例如:

ENV MY_VAR my-value

这种语法不容许在一条 ENV 指令中设置多个环境变量,可能会形成混淆。例如,下面的代码设置了一个值为“TWO= THREE=world”的环境变量(ONE):

ENV ONE TWO= THREE=world

支持这种替代语法为了向后兼容,但因为上述缘由不鼓励使用,可能会在未来的版本中删除。

原文连接:https://k8scat.com/posts/dockerfile-env/

相关文章
相关标签/搜索