Dockerfile FROM指令 语法解析
凡是编写Dockerfile,几乎开始都会是FROM
命令,它决定了Dockerfile构建出的镜像为何物,本文就来了解一下FROM
的语法、语义以及对应的示例。
语法
FROM [--platform=<platform>] <image> [AS <name>]
FROM [--platform=<platform>] <image>[:<tag>] [AS <name>]
FROM [--platform=<platform>] <image>[@<digest>] [AS <name>]
语义
1. FROM
指令开始一个新的构建阶段,设置后续构建依赖的基础镜像,Dockerfile
必须以FROM
开始。镜像可以是任意有效镜像。
示例:在nginx:latest
镜像基础上,直接创建一个新的镜像。
FROM nginx
CMD /bin/bash
2. Dockerfile
必须以FROM
指令开始(除ARG
指令之外),否则会出现"Please provide a source image with from
prior to commit"。
CMD echo "Before FROM"
FROM nginx
CMD /bin/bash
3. FROM
可以在一个Dockerfile
中出现多次,以创建多个镜像或者将当前构建作为另一个构建的依赖。
4. 通过向FROM指令添加AS name,可以选择为新生成阶段指定名称。该名称可以在后续的FROM
和COPY --FROM=<name>
指令中使用,以引用在此阶段中构建的镜像。
示例:详细应用示例会在系列博文中展示。
FROM nginx AS firstNginx
CMD /bin/bash
5. tag
或者digest
的值是可选的。如果省略其中任何一个,则默认情况下,构建器使用latest
作为默认值。如果找不到tag
的值,则构建器返回错误。
示例:直接不存在的镜像nginx:109
,下载出现错误。
FROM nginx:109
CMD /bin/bash
6. --platform
可以用于指定镜像的平台,用来处理那些支持多平台的镜像。例如:linux/amd64
、linux/arm64
或windows/amd64
。默认情况下,使用生产请求的平台。全局生成参数可用于此标志的值,例如:自动平台参数允许您强制一个阶段到本机构建平台(--platform=$BUILDPLATFORM
),并使用它交叉编译到阶段内部的目标平台。
示例:nginx:latest
作为基础镜像,指定--platform=linux/arm64
进行镜像构建。
FROM --platform=linux/arm64 nginx
CMD /bin/bash
7. FROM
与ARG
上文(2)中曾提到过, Dockerfile
必须以FROM
指令开始(除ARG
指令之外),下面来看下FROM
与ARG
的关系。
7.1 FORM
的参数支持在FORM
之前由ARG
定义的变量。
示例:在FROM
之前通过ARG
定义变量NG_VERSION,在FROM
中引用变量。
ARG NG_VERSION=1.19.3
FROM nginx:${NG_VERSION}
CMD /bin/bash
7.2 FORM
之前声明的ARG
参数游离在构建阶段之外,所以不可以在FORM
之后的任何指令中使用。如果想使用FORM
前声明的带有默认值的ARG
,需要在构建阶段通过ARG
声明没有值的同名参数。
ARG NG_VERSION=1.19.3
FROM nginx:${NG_VERSION}
ARG NG_VERSION
RUN echo "${NG_VERSION}"
CMD /bin/bash
总结
FROM
指令应用非常简单,但一定要注意文中罗列的7项内容,避免在实际应用中,由于失误等原因造成不必要的麻烦,本文演示的示例都很简单,都是基于镜像直接创建新的镜像,但如何使用Dockerfile
构建镜像基本也就是这样了。
若文中存在错误和不足,欢迎指正!