前言

学习Dockerfile语法,编写Dockerfile文件

什么是Dockerfile?

Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明

指令说明

  1. Dockerfile 的指令摘要
  2. FROM- 镜像从那里来
  3. MAINTAINER- 镜像维护者信息
  4. RUN- 构建镜像执行的命令,每一次RUN都会构建一层
  5. CMD- 容器启动的命令,如果有多个则以最后一个为准,也可以为ENTRYPOINT提供参数
  6. VOLUME- 定义数据卷,如果没有定义则使用默认
  7. USER- 指定后续执行的用户组和用户
  8. WORKDIR- 切换当前执行的工作目录
  9. HEALTHCHECH- 健康检测指令
  10. ARG- 变量属性值,但不在容器内部起作用
  11. EXPOSE- 暴露端口
  12. ENV- 变量属性值,容器内部也会起作用
  13. ADD- 添加文件,如果是压缩文件也解压
  14. COPY- 添加文件,以复制的形式
  15. ENTRYPOINT- 容器进入时执行的命令

FROM

说明:FROM是指定基础镜像,必须为第一个命令

  1. 语法:
  2. FROM <image>:<tag>
  3. 示例:
  4. FROM mysql:5.7

RUN

说明:RUN 用来执行构建镜像时执行的命令,有以下两种命令执行方式

  1. 语法:
  2. `shell` 执行格式:
  3. RUN <command>
  4. `exec` 执行格式:
  5. RUN ["executable", "param1", "param2"]
  6. 示例:
  7. `shell`格式:
  8. RUN apk update
  9. `exec`格式:
  10. RUN ["/dev/file", "p1", "p2"]

COPY

说明:复制指令,从上下文目录中复制文件或者目录到容器里指定路径

  1. 语法:
  2. COPY [--chown=<user>:<group>] <源路径1>... <目标路径>
  3. COPY [--chown=<user>:<group>] ["<源路径1>",... "<目标路径>"]
  4. **[--chown=<user>:<group>]**:可选参数,用户改变复制到容器内文件的拥有者和属组。
  5. **<源路径>**:源文件或者源目录,这里可以是通配符表达式。
  6. **<目标路径>**:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。
  7. 示例:
  8. COPY hom* /mydir/
  9. COPY hom?.txt /mydir/

ADD

说明:ADD 指令和 COPY 的使用格类似(同样需求下,官方推荐使用 COPY)。
COPY不同之处:

  • ADD 的优点:在执行 <源文件> 为 tar 压缩文件的话,压缩格式为 gzip, bzip2 以及 xz 的情况下,会自动复制并解压到 <目标路径>。
  • ADD 的缺点:在不解压的前提下,无法复制 tar 压缩文件。会令镜像构建缓存失效,从而可能会令镜像构建变得比较缓慢。具体是否使用,可以根据是否需要自动解压来决定。 ```dockerfile 语法: ADD

    用于支持包含空格的路径

    ADD [““,… ““]

示例: ADD home /path/ # 支持通配符 添加所有以”home”开头的文件 到/path/ 下

  1. <a name="EXPOSE"></a>
  2. ### EXPOSE
  3. 说明:`EXPOSE` 指定与外界交互的端口<br />作用:
  4. - 帮助镜像使用者理解这个镜像服务的守护端口,以方便配置映射。
  5. - 在运行时使用随机端口映射时,也就是 docker run -P 时,会自动随机映射 EXPOSE 的端口。
  6. ```dockerfile
  7. 语法:
  8. EXPOSE <端口1> [<端口2>...]
  9. 示例:
  10. EXPOSE 8080 443

ENV 指令

说明:ENV 用来设置环境变量

  1. 语法:
  2. ENV <key> <value> # 之后的所有内容均会被视为其的组成部分,因此,一次只能设置一个变量
  3. ENV <key>=<value> ... #可以设置多个变量,每个变量为一个"="的键值对,如果中包含空格,可以使用\来进行转义,也可以通过""来进行标识;另外,`\` 也可以用于续行
  4. 示例:
  5. ENV version 1.0.0
  6. ENV version=1.0.0

CMD

说明:CMD 构建容器后执行的命令,也就是在容器启动时才执行的命令。

  1. 语法:
  2. # 执行可执行文件,优先执行
  3. CMD ["executable","param1","param2"]
  4. # 设置了 ENTRYPOINT,则直接调用ENTRYPOINT添加参数 参见 CMD 讲解
  5. CMD ["param1","param2"]
  6. # 执行shell命令
  7. CMD command param1 param2
  8. 示例:
  9. CMD ["/usr/bin/bash","--help"]

WORKDIR

说明:WORKDIR 用来指定工作目录,类似于我们通常使用的cd 命令

  1. 语法:
  2. WORKDIR <PATH>
  3. 示例:
  4. WORKDIR /user/local

VOLUME

说明:VOLUME 用于指定持久化目录

  1. 语法:
  2. VOLUME ["<路径1>", "<路径2>"...]
  3. VOLUME <路径>
  4. # 在启动容器 docker run 的时候,我们可以通过 -v 参数修改挂载点
  5. 示例:
  6. VOLUME ["/data"]
  7. VOLUME ["/var/www", "/var/log/apache2", "/etc/apache2"]

ENTRYPOINT

说明:ENTRYPOINT 用来配置容器,使其可执行化。配合 CMD可省去 application,只使用参数。

  1. 语法:
  2. # 可执行文件, 优先
  3. ENTRYPOINT ["executable", "param1", "param2"]
  4. # shell内部命令
  5. ENTRYPOINT command param1 param2
  6. 示例:
  7. ENTRYPOINT ["top", "-b"]

LABEL

说明:LABEL:用于为镜像添加元数据,多用于声明构建信息,作者、机构、组织等。

  1. 语法:
  2. LABEL <key>=<value> <key>=<value> <key>=<value> ...
  3. 示例:
  4. LABEL version="1.0" description="felord.cn" by="Felordcn"

Dockerfile编写

示例1

  1. # 使用 aws 的java jdk 8
  2. FROM amazoncorretto:8
  3. # 作者等相关的元信息
  4. LABEL AUTHOR=Felordcn OG=felord.cn
  5. # 挂载卷
  6. VOLUME ["/tmp","/logs"]
  7. # 时区
  8. ENV TZ=Asia/Shanghai
  9. # 启用配置文件 默认为 application.yml
  10. ENV ACTIVE=defualt
  11. # 设置镜像时区
  12. RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
  13. # 修改为打包后的jar文件名称
  14. ADD /target/flyway-spring-boot-1.0.0.jar app.jar
  15. ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-Dspring.profiles.active=${ACTIVE}","-jar","app.jar"]

示例2

  1. # Docker image for springboot file run
  2. # VERSION 0.0.1
  3. # Author: eangulee
  4. # 基础镜像使用java
  5. FROM java:8
  6. # 作者
  7. MAINTAINER eangulee <tom@gmail.com>
  8. # VOLUME 指定了临时文件目录为/tmp。
  9. # 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
  10. VOLUME /tmp
  11. # 将jar包添加到容器中并更名为app.jar
  12. ADD cloud-test-1.0-SNAPSHOT.jar app.jar
  13. # 运行jar包
  14. RUN bash -c 'touch /app.jar'
  15. ENTRYPOINT ["java","-jar","/app.jar"]

总结

本文记录了dockerfile的指令使用及说明,另外和两个springboot项目dockerfile的示例