Dockerfile由一行行命令语句组成,并且支持用“#”开头作为注释,一般的,Dockerfile分为四部分:基础镜像信息,维护者信息,镜像操作指令和容器启动时执行的指令。

Dockerfile指令

1、FROM

  1. 格式:FROM <image> FROM <image>:<tag>

第一条指令必须为FROM指令,并且,如果在同一个Dockerfile中创建多个镜像时,可以使用多个FROM指令(每个镜像一次)

2、MAINTAINET

  1. 格式:MAINTAINET <name>

指定维护者的信息

3、RUN

  1. 格式:RUN <command> RUN ["", "", ""]

每条指令将在当前镜像基础上执行,并提交为新的镜像。(可以用“\”换行)

4、CMD

  1. 格式:CMD ["","",""]

指定启动容器时执行的命令,每个Dockerfile只能有一条CMD指令,如果指定了多条指令,则最后一条执行。(会被启动时指定的命令覆盖)

5、EXPOSE

  1. 格式:EXPOSE <port> [ <port> ...]

告诉Docker服务端暴露端口,在容器启动时需要通过 -p 做端口映射

6、ENV

  1. 格式:ENV <key> <value>

指定环境变量,会被RUN指令使用,并在容器运行时保存

7、ADD

  1. 格式:ADD <src> <dest>

复制指定的到容器的中,可以是Dockerfile所在的目录的一个相对路径;可以是URL,也可以是tar.gz(自动解压)

8、COPY

  1. 格式:COPY <src> <dest>

复制本地主机的 ( 为 Dockerfile 所在目录的相对路径)到容器中的 (当使用本地目录为源目录时,推荐使用 COPY)

9、ENTRYPOINT

  1. 格式:ENTRYPOINT ["","",""]

配置容器启动后执行的命令,并且不可被 docker run 提供的参数覆盖。(每个 Dockerfile 中只能有一个 ENTRYPOINT ,当指定多个时,只有最后一个起效)

10、VOLUME

  1. 格式:VOLUME ["/mnt"]

创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等

11、USER

  1. 格式:USER daemon

指定运行容器时的用户名或 UID,后续的 RUN 也会使用指定用户。

12、WORKDIR

  1. 格式:WORKDIR /path/to/workdir

为后续的 RUN 、 CMD 、 ENTRYPOINT 指令配置工作目录。(可以使用多个 WORKDIR 指令,后续命令如果参数是相对路径, 则会基于之前命令指定的路径)

13、ONBUILD

  1. 格式:ONBUILD [INSTRUCTION]

配置当所创建的镜像作为其它新创建镜像的基础镜像时,所执行的操作指令

例子

将需要使用的jdk(jdk1.7.0_79)和已经编译好的包( websocket.jar)放到和dockerfile相同的文件夹下面,dockerfile如下:

  1. FROM centos
  2. # 镜像是centos
  3. MAINTAINER CrissChan
  4. # 维护者CrissChan
  5. COPY jdk1.7.0_79 jdk1.7.0_79
  6. # 复制JDK
  7. ADD websocket.jar app.jar
  8. # 将项目的添加到容器中,并修改名字为app.jar
  9. ENV JAVA_HOME=/jdk1.7.0_79
  10. ENV PATH=$JAVA_HOME/bin:$PATH
  11. ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
  12. # 配置jdk环境
  13. EXPOSE 8080
  14. # 容器对外提供服务的端口是8080
  15. ENTRYPOINT ["java","-jar","/app.jar"]
  16. #启动容器后启动app.jar的应用

编译并生成镜像 (. 表示当前路径)

  1. docker build -t oliver/helloDocker .

查看生成的镜像

  1. docker images

创建容器并运行

  1. docker run -p 192.168.0.105:8080:8080 --name helloDocker oliver/helloDocker