常用Dockerfile
命令汇总。
命令 意义 使用示例 FROM
FROM
指令必须是Dockerfile
中非注释行的第一个指令,为镜像文件构建过程指定基础镜像,后续的指令运行于此基础镜像所提供的运行环境FROM busybox:latest
MAINTAINER
用于让 dockerfile
制作者提供本人的详细信息。MAINTAINER "minglog <luoming@tipdm.com>"
COPY
用于从 docker
主机复制新文件或者目录至创建的新镜像指定路径中。COPY <src> <dest>
ADD
指令类似于 COPY
指令,ADD
支持使用TAR
文件和URL
路径#拷贝当前目录下的bin文件夹的所有文件到/usr/bin目录下( /usr/bin
目录原有的文件会保留)ADD ./bin/ /usr/bin/
WORKDIR
用于为 Dockerfile
中所有的RUN
、CMD
、ENTRYPOINT
、COPY
和ADD
指令设定工作目录WORKDIR <dirpath>
VOLUME
用于在 image
中创建一个挂载点目录VOLUME <mountpoint>
EXPOSE
用于为容器打开指定要监听的端口以实现与外部通信 EXPOSE <port>[/ <protocol>] [<port>[/ <protocol>]
<protocol>
用于指定传输层协议,可为tcp
或udp
二者之一,默认为TCP
协议EXPOSE
指令可一次指定多个端口,例如:EXPOSE 11211/udp 11211/tcp
ENV
用于为镜像定义所需的环境变量,并可被 Dockerfile
文件中位于其后的其它指令(如ENV
、ADD
、COPY
等)所调用 调用格式为$variable_ name
或${variable_ name}
ENV <key> <value>
一次只能设置一个
或ENV <key>=<value>
一次可以设置多个键值对RUN
用于指定 docker build
过程中运行的程序,其可以是任何命令1,. RUN <command>
通常是一个 shell
命令
2.RUN ["<executable>", "<param1>", "<param2>"]
CMD
类似于 RUN
指令,CMD
指令也可用于运行任何命令或应用程序。RUN
指令运行于映像文件构建过程中,而CMD
指令运行于基于Dockerfile
构建出的新映像文件启动一个容器时。CMD
指令的首要目的在于为启动的容器指定默认要运行的程序,且其运行结束后,容器也将终止;不过,CMD
指定的命令其可以被docker run
的命令行选项所覆盖。Dockerfile
中可以存在多个CMD
指令,但仅最后一个会生效。CMD <command>
或CMD ["<executable>","<param1>","<param2>"]
或CMD ["<param1>","<param2>"]
ENTRYPOINT
类似 CMD
指令的功能,用于为容器指定默认运行程序,从而使得容器像是一个单独的可执行程序
与CMD
不同的是,由ENTRYPOINT
启动的程序不会被docker run
命令行指定的参数所覆盖,而且,这些命令行参数会被当作参数传递给ENTRYPOINT
指定指定的程序。
不过,docker run
命令的--entrypoint
选项的参数可覆盖ENTRYPOINT
指令指定的程序。ENTRYPOINT <command>
或ENTRYPOINT ["<executable>", "<param1>", "<param2>"]
HEALTHCHECK
HEALTHCHECK
指令告诉Docker
如何测试容器以检查它是否仍在工作。即使服务器进程仍在运行,这也可以检测出陷入无限循环且无法处理新连接的Web
服务器等情况。HEALTHCHECK [OPTIONS] CMD command
(通过在容器内运行命令来检查容器运行状况)HEALTHCHECK NONE
(禁用从基础映像继承的任何运行状况检查)ONBUILD
用于在 Dockerfile
中定义一个触发器Dockerfile
用于build
映像文件,此映像文件亦可作为base image
被另一个Dockerfile
用作FROM
指令的参数,并以之构建新的映像文件
在后面的这个Dockerfile
中的FROM
指令在build
过程中被执行时,将会“触发”创建其base image
的Dockerfile
文件中的ONBUILD
指令定义的触发器。ONBUILD < Instruction>
尽管任何指令都可注册成为触发器指令,但ONBUILD
不能自我嵌套,且不会触发FROM
和MAINTAINER
指令
使用包含ONBUILD
指令的Dockerfile
构建的镜像应该使用特殊的标签,例如ruby:2.0-onbuil
在ONBUILD
指令中使用ADD
或COPY
指令应该格外小心,因为新构建过程的上下文在缺少指定的源文件时会失败USER
用于指定运行 image
时的或运行Dockerfile
中任何RUN
、CMD
或EntRyPoInT
指令指定的程序时的用户名或UID
默认情况下,container
的运行身份为root
用户。USER <UID>或<U Username>
需要注意的是,<UID>
可以为任意数字,但实践中其必须为/etc/ passwd
中某用户的有效UID
,否则,docker run
命令将运行失败ARG
ARG
指令类似ENV
,定义了一个变量;区别于ENV
:用户可以在构建时docker build --build-arg <varname> = <value>
进行对变量的修改;ENV
不可以,如果用户指定了未在Dockerfile
中定义的构建参数,那么构建输出警告ARG <name>[= <default value>]
Dockerfile
可以包含一个或多个ARG
指令SHELL
SHELL
指令允许覆盖用于shell
命令形式的默认shell
。Linux
上的默认shell
是[“/ bin / sh”,“c”]
,在Windows上是[“cmd”,“/ S”,“/ C”] SHELL
指令必须以JSON
格式写入Dockerfile
。SHELL ["executable", "parameters"]
SHELL
指令可以多次出现。 每个SHELL
指令都会覆盖所有先前的SHELL
指令,并影响所有后续指令。STOPSIGNAL
STOPSIGNAL
指令设置将发送到容器出口的系统调用信号 此信号可以是与内核的系统调用表中的位置匹配的有效无符号数,例如9
,或者SIGNAME
格式的信号名,例如SIGKILL
。STOPSIGNAL signal