-
-
COPY 用户从宿主机的当前目录复制文件至建立的新映像文件 |
COPY <src> <dest>
COPY ["<src>",..."<dest>"]
<src>为要复制的源文件或目录,支持使用通配符
<dest>为目标路径,建议使用绝对路径
复制代码
- 必须是build上下文中的路径,不能是其父目录中的文件
- 若是是目录,则其内部文件或子目录会被递归复制, 可是目录自己不会被复制
-
ADD 相似于COPY指令,ADD支持使用tar文件和URL路径 |
操做如COPY
复制代码
若是是一个本地系统上压缩格式的tar文件,它降被展开为一个目录,其行为相似 "tar -x"命令,经过url获取到的tar文件将不会自动展开;html
-
WORKDIR 用于为Dockerfile中全部的RUN、CMD、ENTRYPOINT、COPY和ADD指定工做目录 |
WORKDIR /usr/local/
ADD nginx-1.15.2.tar.gz ./src/
复制代码
定义存储卷,只能制定容器内部的目录nginx
-
EXPOSE 用户为容器打开制定要监听的端口以实现与外部通讯 |
EXPOSE <port>
EXPOSE 11211/udp 11211/tcp
复制代码
只有docker run 加 -P选项时才会将端口暴漏出来,若是不加,将不暴漏端口web
[root@cv0002 docker]
[root@cv0002 ~]
[root@cv0002 ~]
[root@cv0002 docker]
[root@cv0002 ~]
80/tcp -> 0.0.0.0:1024
复制代码
-
ENV 用于为镜像定义所需的环境变量,并可被Dockerfile文件中位于其后的其余指令(如ENV,ADD,COPY等)所调用,调用格式为\$variable或${variable} |
ENV <key> <value>或
ENV <key>=<value> ...
复制代码
- 第二种格式能够设置多个变量,若中包含空格,可使用反斜线转义,也可经过对加引号来标识,反斜线也能够用于续行
- 定义多个变量时,建议使用第二种方式,以便在同一层中完成全部功能。
- 若是在命令行中定义-e 更改环境变量,也只是更改了环境变量,以前编译时候作的改变是更改不了的。
[root@cv0002 docker]
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=a2c3f68db164
DOC_ROOT=/data/web/html/
WEB_SERVER_PACKAGE=nginx-1.15.2
HOME=/root
[root@cv0002 docker]
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=27213da32d60
WEB_SERVER_PACKAGE=nginx-1.15.1
DOC_ROOT=/data/web/html/
HOME=/root
[root@cv0002 docker]
nginx-1.15.2
复制代码
RUN和CMD 如图所示
- RUN 在docker build中运行,构建镜像时为了使镜像完整使用的命令。在初始化容器时候时不可能再运行。
- CMD 定义一个镜像文件启动为容器时候默认要运行的程序,且其运行结束后,容器也将终止,而docker容器默认只运行一个程序。CMD指令能够被docker run 的命令行所覆盖
注意:RUN命令在Dockerfile中能够有多个,且能够都生效,可是CMD有多个的话,但只有最后一个生效docker
RUN <command>
RUN ["<executable>","<param1>","<param2>"]
复制代码
- 第一种格式,一般是一个shell命令,且以"/bin/sh -c "来运行它,这意味着此进程在容器中的PID不为1,不能接收unix信号(由于接收信号的都是进程为1的来接收),所以,当使用docker stop 命令中止容器时,此京城接收不到sigterm信号;
- 第二种语法格式中的参数是一个json格式的数组,其中为要运行的命令,后面为参数。然而,此格式的命令不会以"/bin/sh -c" 来发起,所以不支持通配符等shell特性
注意:Json数组中,要使用双引号shell
CMD <command>
CMD ["<executable>","<param1>","<para 复制代码
- 前两种语法格式的意义同RUN
- 第三种则用于为ENTRYPOINT指令提供默认参数
- 相似CMD指令的功能,用于为容器指定默认运行程序,从而使得容器像是一个单独的可执行程序
- 与CMD不一样的是,有ENTRYPOINT启动的程序不会被docker run命令行制定的参数所覆盖,并且,这些命令行参数会被当作参数传递给ENTRYPOINT制定的程序,但会被docker run命令的--entryporint选项的参数可覆盖ENTRYPOINT指令制定的程序
ENTRYPOINT <command>
ENTRYPOINT [<"<executable>","<param1>","<param2>">]
复制代码
注意:docker run传入的命令参数会覆盖CMD指令的内容而且附加到ENTRYPOINT命令最后做为其参数使用json
注意:Dockerfile文件中也能够存在多个ENTRYPOINT指令,但仅有最后一个会生效数组
-
用于指定运行的image时的或运行Dockerfile中的任何RUN、CMD、或ENTRYPOINT指令指定的程序时的用户名或UID,默认为root用户
USER <UID>|<username>
复制代码
注意:能够为任意数字,可是事件中必须为/etc/passwd中某用户的有效UID,不然docker run命令将运行失败bash
HEALTHCHECK --start-period=3s CMD wget -O - -q http://${IP:-0.0.0.0}:${PORT:-80}/
复制代码
-
SHELL 修改或额外定义运行程序的默认shell |
复制代码
-
STOPSIGNAL 更好docker stop 传过来的信号指令,默认为15 |
STOPSIGNAL signal
复制代码
-
ARG 只再build中使用,相似变量,能够在docker run的时候经过--build-tag传值,而ENV不可在docker run时传值。 |
-
ONBUILD 用于在Dockerfile中定义一个触发器(延时执行) |
ONBUILD <指令>
复制代码
当此Dockerfile被build为映像文件后,此映像文件亦可做为base image被另外一个Dockerfile用做FROM指令的参数,并以之构建新的映像文件,此时,ONBUILD后的指令才会执行。tcp
注意:在ONBUILD指令中使用ADD或COPY指令应该格外当心,由于新构建过程的上下文有可能会缺乏源文件ui
喜欢我写的东西的朋友能够关注一下个人公众号:Devops部落 |