Dockerfile结构
通常dockfile包含4部分
- 基础镜像
- 维护者信息
- 镜像操作指令
- 容器启动时执行指令
dockerfile示例
#这是一个示例
#基于ubuntu image
#version 2
#author:me
#command format: Instruction [arg/command]
#第一行必须是指定的基础镜像
FROM ubuntu
#维护者信息,名称和信箱
MAINTAINER dockeruser docker@docker.com
#镜像的操作指令,每执行一次run指令,镜像就添加一层
RUN echo “deb http://archive.ubuntu.com/ubuntu/ raring main universe ” >>/etc/apt/ources.list
RUN apt-get update && apt-get install -y nginx
#容器启动时执行的指令
CMD /usr/sbin/nginx
操作指令
1.FROM
FROM image,引出基础镜像。一个dockerfile可以引入多个基础镜像。
2.MAINTAINER
MAINTAINER <name>指定维护者信息
3.RUN
RUN <command> 在shell终端中运行命令,即/bin/sh -C
RUN["executable","param1","param2"] 使用exec执行。
命令较长时,可以使用\换行
4.CMD
指定容器启动时执行的命令,每个dockerfile只能有1条CMD命令,多个CMD只会执行最后一条。容器启动时,指定了运行命令,则会覆盖到dockerfile里的CMD命令。
* CMD ["executable","para1","para2"]使用exec执行,推荐使用。
* CMD command para1 para2 在/bin/sh中执行,提供给需要交互的应用。
* CMD ["para1","para2"]提供给ENTRYPOINT的默认参数。
5.EXPOSE
EXPOSE<port> [<port>]指定暴露给主机的端口。
6.ENV
ENV <key> <value>指定环境变量,后续的run指令使用,并在容器运行期间保持
7.ADD
ADD <src> <dest>将src指定目录或url的文件或目录,复制到容器的dest
8.COPY
COPY <src> <dest>对于dockerfile所在目录现对路径文件或目录,复制到容器的dest,dest不存在会自动创建。
9.ENTRYPOINT
配置容器启动后执行的命令,不能被docker run提供的参数覆盖。每个dockerfile只能有一个ENTRYPOINT,多个ENTRYPOINT只有最后一个生效。
ENTRYPOINT ["executable","para1","para2"]
ENTRYPOINT command para1 para2(在shell中执行)。
10.VOLUME
VOLUME [“/data”] 创建一个可以从宿主机或其他容器挂载的挂载点。
11.USER
USER daemon指定容器运行时的用户名或uid,也可以在RUN时指定用户
12.WORKDIR
WORKDIR /path/to/workdir 为后续的RUN、CMD、ENTRYPOINT指定配置工作目录,可以使用多个WORKDIR指令,后续命令如果参数是相对目录,则会基于之前命令的路径。
13.ONBUILD
配置从当前镜像创建其他镜像时,执行的指令
创建镜像
docker build
编写为dockerfile后,通过该命令来创建镜像。docker build [option] path 读取指定路径下(含子目录)的dockerfile,并将该路径下所有内容发送给docker服务端,有服务端来创建镜像,因此一般建议防止dockerfile的目录为空目录。