美文网首页
Dockerfile使用手册

Dockerfile使用手册

作者: 为了明天_加油 | 来源:发表于2017-04-17 19:37 被阅读0次

    Dockerfile是一个文本格式的配置文件,可以用该文件快速创建自定义镜像。

    1、基本结构

    Dockerfile由一行行命令语句组成,并且支持#开头的注释;

    该文件一般分为四部分:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行的指令,例如:

    #第一行必须指定基于的基础镜像

    FROM centos

    #维护者信息

    MAINTAINER bwwg bwwg@163.com

    #镜像的操作指令,每运行一条RUN指令,镜像添加新的一层,并提交

    RUN yum -y install openssh-server openssh

    #容器启动时执行的指令

    CMD /usr/sbin/sshd

    2、指令

    指令包括FROM、MAINTAINER、RUN等;

    2.1 FROM

    格式为FROM

    或FROM

    :

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

    2.2 MAINTAINER

    格式为MAINTAINER

    ,指定维护者信息;

    2.3 RUN

    格式为RUN

    或RUN["executable", "param1", "param2"]

    前者将在Shell终端中运行命令,即/bin/sh -c;后者则使用exec执行。指定使用其他终端可以通过第二种方式实现,例如RUN ["/bin/bash", , "-c", , "echohello"];

    每条RUN指令将在当前镜像基础上执行指定命令,并提交为新的镜像,当命令过长时可使用\换行;

    2.4 CMD

    指定启动容器时执行的命令,支持三种格式:

    CMD["executable","param1","param2"]推荐方式;

    CMDcommand param1 param2在/bin/sh中执行,提供给需要交互的应用;

    CMD ["param1","param2"]提供给ENTRYPOINT的默认参数

    每个Dockerfile只能有一条CMD指令,如果指定了多条命令,只有最后一条会被执行;

    如果用户在启动容器时指定了运行的命令,则会覆盖掉CMD指定的命令;

    2.5 EXPOSE

    指定容器可暴露的端口号,共互联系统使用,格式为EXPOSE[...]

    2.6 ENV

    格式为ENV

    指定一个环境变量,会被后续RUN指令使用,并在容器运行时保持,例如:

    ENV PATH /usr/local/bin:$PATH

    2.7 ADD

    格式为ADD

    该命令将复制指定的到容器中的。其中可以是Dockerfile所在目录的一个相对路径(文件或目录);也可以是一个URL;还可以是一个tar,gzip,bzip2,xz文件(自动解压为目录);

    可以是绝对路径,也可以是相对于WORKDIR的路径,例如:

    ADD test relativeDir/#adds "test" to `WORKDIR`/relativeDir/

    ADD test /absoluteDir/#adds "test" to /absoluteDir/

    注意:目录本身不复制,仅复制该目录下的所有内容

    2.8 COPY

    格式为COPY

    复制本地主机的(为Dockerfile所在目录的相对路径,文件或目录)至容器中的。目标路径不存在时,会自动创建。

    当使用本地目录为目录时,推荐使用COPY。

    2.9 ENTRYPOINT

    有两种格式:

    ENTRYPOINT ["executable","param1", "param2"]

    ENTRYPOINT command param1 param2在容器的Shell中执行

    配置容器启动后执行的命令,并且不可被docker run提供的参数覆盖;

    每个Dockerfile中只能有一个ENTRYPOINT,当指定了多个ENTRYPOINT时,只有最后一个生效。

    当执行docker run命令时,也可以添加-entrypoint参数,会把指定的参数继续传递给ENTRYPOINT,例如:

    ...

    ENTRYPOINT ["echo","foo"]

    然后执行:

    docker run CONTAINER_NAME bar #注意没有echo

    那么,就相当于执行了echo foo bar,最终结果就是

    foo bar

    CMD与ENTRYPOINT的异同

    http://cloud.51cto.com/art/201411/457338.htm

    2.10 VOLUME

    格式为VOLUME

    ["/data"]

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

    2.11 USER

    格式为USER用户名

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

    当服务不需要管理员权限时,可以通过该命令指定运行用户。并且可以在之前创建所需要的用户,例如:RUN groupadd -r postgres && useradd -r -g postgres postgres。要临时获取root权限可以使用gosu,不推荐sudo。

    2.12 WORKDIR

    格式为WORKDIR

    /path/to/workdir

    为后续的RUN、CMD、ENTRYPOINT指令配置工作目录;

    可以使用多个WORKDIR指令,后续命令如果参数是相对路径,则会基于之前命令指定的路径,例如:

    WORKDIR /a

    WORKDIR b

    WORKDIR c

    RUN pwd

    则最终路径为/a/b/c

    2.13 ONBUILD

    格式为ONBUILD

    [INSTRUCTION]

    配置当所创建的镜像为其他新创建镜像的基础镜像时,所执行的操作指令。例如:

    Dockerfile使用如下的内容创建了镜像image-A

    [...]

    ONBUILD ADD . /app/src

    ONBUILD RUN /usr/local/bin/python-build --dir /app/src

    [...]

    如果基于image-A创建新的镜像时,新的Dockerfile中使用FROM image-A指定基础镜像时,会自动执行上面的ONBUILD指令内容,等价于在后面添加了两条指令:

    FROM image-A

    ADD. /app/src

    RUN /usr/local/bin/python-build --dir /app/src

    使用ONBUILD指令的镜像,推荐在标签中注明,例如centos:6.8-onbuild

    3、创建镜像

    编写完Dockerfile后,通过docker

    build命令创建镜像。

    基本的格式为docker

    build [选项]路径,该命令读取指定路径下(包括子目录)的Dockerfile,并将该路径下所有内容发送给Docker服务端来创建镜像。

    另外,可以通过.dockerignore文件(其中每一行添加一条匹配模式)来让Docker忽略路径下的目录和文件。

    要指定镜像的标签(tag)信息,可以通过-t选项。

    例如:

    指定Dockerfile文件所在路径为/tmp/docker_builder/,并且希望生成镜像标签为build_repo/first_image,可使用如下命令:

    docker build -t build_repo/first_image /tmp/docker_builder

    相关文章

      网友评论

          本文标题:Dockerfile使用手册

          本文链接:https://www.haomeiwen.com/subject/tfqxzttx.html