Dockerfile是为快速构建docker image而设计的,当你使用dockerbuild 命令的时候,docker 会读取当前目录下的命名为Dockerfile(首字母大写)的纯文本文件并执行里面的指令构建出一个docker image。
Dockerfile 由一行行命令语句组成,并且支持以#开头的注释行。指令是不区分大小写的,但是通常我们都大写。
以下是关于如何构建nginx静态服务器的Dockerfile示例代码:
FROM daocloud.io/library/nginx
ADD ./nginx.conf /etc/nginx/nginx.conf RUN mkdir -p /data/xxx/web COPY ./dist /data/xxx/web/dist WORKDIR / EXPOSE 80
一般的,我们将Dockerfile 分为四部分:
- 基础镜像信息 、维护者信息(FROM、LABEL)
- 镜像操作指令 (ADD、RUN 、COPY、WORKDIR、EXPOSE)
- 容器启动时执行指令 (CMD)
Dockerfile指令详解
下面我们来分别介绍下上面使用到的命令:
FROM
格式:FROM<image>或FROM<image>:<tag>。
解释:FROM是Dockerfile里的第一条指令(必须是),后面跟有效的镜像名(如果该镜像你的本地仓库没有则会从远程仓库Pull取)。然后后面的其它指令FROM的镜像中执行。
LABEL
格式:LABEL key="value"
解释:新版本docker不再推荐 用MAINTAINER标注维护者信息,推荐使用 LABEL author="lhy"的方式标记
RUN
格式:RUN <command>或 RUN[“executable”, “param1”, “param2”]。
解释:运行命令,命令较长使可以使用来换行。推荐使用上面数组的格式
COPY
格式:COPY <src>… <dest>
解释:将指定的<src>复制到容器文件系统中的<dest>
这里把我们项目目录本身,即当前目录 .
拷贝至容器的 /app
位置。然后通过指令 WORKDIR
将 /app
目录设为工作目录。工作目录可以理解为运行时的 pwd
。
RUN
格式:RUN <command>或 RUN[“executable”, “param1”, “param2”]。
解释:运行命令,命令较长使可以使用来换行。推荐使用上面数组的格式
WORKDIR
格式:WORKDIR/path/to/workdir
解释:切换目录,为后续的RUN、CMD、ENTRYPOINT 指令配置工作目录。
可以多次切换(相当于cd命令),也可以使用多个WORKDIR 指令,后续命令如果参数是相对路径,则会基于之前命令指定的路径。例如
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd
则最终路径为 /a/b/c。
EXPOSE
格式:EXPOSE<port> [<port>…]
解释:设置Docker容器内部暴露的端口号,如果需要外部访问,还需要启动容器时增加-p或者-P参数进行分配。
CMD
格式:
CMD [“executable”,”param1″,”param2″] 使用 exec 执行,推荐方式;
CMD command param1 param2 在 /bin/sh 中执行,提供给需要交互的应用;
CMD [“param1″,”param2”] 提供给ENTRYPOINT的默认参数;
解释:CMD指定容器启动是执行的命令,每个Dockerfile只能有一条CMD命令,如果指定了多条,只有最后一条会被执行。如果你在启动容器的时候也指定的命令,那么会覆盖Dockerfile构建的镜像里面的CMD命令。
以上是关于Dockerfile文件相关知识的简介