• Dockerfile指令总结


    指令的一般格式为INSTRUCTION arguments,指令包含FROMMAINTAINERRUN等。

    FROM

    格式为FROM <image>FROM <image>:<tag>

    第一条指令必须为FROM指令。而且,假设在同一个Dockerfile中创建多个镜像时。能够使用多个FROM指令(每一个镜像一次)。

    MAINTAINER

    格式为MAINTAINER <name>,指定维护者信息。

    RUN

    格式为RUN <command>RUN ["executable", "param1", "param2"]

    前者将在shell终端中执行命令,即/bin/sh -c;后者则使用exec执行。指定使用其他终端能够通过另外一种方式实现,比如RUN ["/bin/bash", "-c", "echo hello"]

    每条RUN指令将在当前镜像基础上运行指定命令,并提交为新的镜像。当命令较长时能够使用来换行。

    CMD

    支持三种格式

    • CMD ["executable","param1","param2"]使用exec运行,推荐方式。
    • CMD command param1 param2/bin/sh中运行。提供给须要交互的应用;
    • CMD ["param1","param2"]提供给ENTRYPOINT的默认參数;

    指定启动容器时运行的命令,每一个Dockerfile仅仅能有一条CMD命令。假设指定了多条命令,仅仅有最后一条会被运行。

    假设用户启动容器时候指定了执行的命令。则会覆盖掉CMD指定的命令。

    EXPOSE

    格式为EXPOSE <port> [<port>...]

    告诉Docker服务端容器暴露的port号,供互联系统使用。

    ENV

    格式为ENV <key> <value>。 指定一个环境变量,会被兴许RUN指令使用,并在容器执行时保持。

    比如

    ENV PG_MAJOR 9.3
    ENV PG_VERSION 9.3.4
    RUN curl -SL http://example.com/postgres-$PG_VERSION.tar.xz | tar -xJC /usr/src/postgress && …
    ENV PATH /usr/local/postgres-$PG_MAJOR/bin:$PATH
    

    ADD

    格式为ADD <src> <dest>

    该命令将复制指定的<src>到容器中的<dest>

    当中<src>能够是Dockerfile所在文件夹的一个相对路径;也能够是一个URL;还能够是一个tar文件(自己主动解压为文件夹)。

    则。

    COPY

    格式为COPY <src> <dest>

    复制本地主机的<src>(为Dockerfile所在文件夹的相对路径)到容器中的<dest>

    当使用本地文件夹为源文件夹时。推荐使用COPY

    ENTRYPOINT

    两种格式:

    • ENTRYPOINT ["executable", "param1", "param2"]
    • ENTRYPOINT command param1 param2(shell中运行)。

    配置容器启动后运行的命令。而且不可被docker run提供的參数覆盖。

    每一个Dockerfile中仅仅能有一个ENTRYPOINT。当指定多个时。仅仅有最后一个起效。

    VOLUME

    格式为VOLUME ["/data"]

    创建一个能够从本地主机或其它容器挂载的挂载点,一般用来存放数据库和须要保持的数据等。

    USER

    格式为USER daemon

    指定执行容器时的username或UID,兴许的RUN也会使用指定用户。

    当服务不须要管理员权限时,能够通过该命令指定执行用户。而且能够在之前创建所须要的用户,比如:RUN groupadd -r postgres && useradd -r -g postgres postgres

    要暂时获取管理员权限能够使用gosu,而不推荐sudo

    WORKDIR

    格式为WORKDIR /path/to/workdir

    为兴许的RUNCMDENTRYPOINT指令配置工作文件夹。

    能够使用多个WORKDIR指令,兴许命令假设參数是相对路径,则会基于之前命令指定的路径。比如

    WORKDIR /a
    WORKDIR b
    WORKDIR c
    RUN pwd
    

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

    ONBUILD

    格式为ONBUILD [INSTRUCTION]

    配置当所创建的镜像作为其他新创建镜像的基础镜像时。所运行的操作指令。

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

    [...]
    ONBUILD ADD . /app/src
    ONBUILD RUN /usr/local/bin/python-build --dir /app/src
    [...]
    

    假设基于A创建新的镜像时。新的Dockerfile中使用FROM image-A指定基础镜像时,会自己主动运行ONBUILD指令内容,等价于在后面加入了两条指令。

    FROM image-A
    
    #Automatically run the following
    ADD . /app/src
    RUN /usr/local/bin/python-build --dir /app/src
    

    使用ONBUILD指令的镜像,推荐在标签中注明,比如ruby:1.9-onbuild

  • 相关阅读:
    drf 权限流程解析
    drf 认证流程解析
    drf 版本解析
    Django REST framework初识
    RESTful规范
    Flask框架
    Flask框架解析目录
    hdu
    hdu 6113 度度熊的01世界(结构体的赋值问题)
    hdu 6114 chess(排列组合)
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/5221591.html
Copyright © 2020-2023  润新知