• 【Docker】Dockerfile 之 RUN


    参考教程:https://docs.docker.com/engine/reference/builder/

    环境

    1. virtual box 6.1
    2. centos 7.8
    3. docker 19.03

    RUN

    RUN has 2 forms:

    RUN 有 2 种格式:

    • RUN <command> (shell form, the command is run in a shell, which by default is /bin/sh -c on Linux or cmd /S /C on Windows)

    • RUN ["executable", "param1", "param2"] (exec form)

    • RUN <command>shell 形式,该命令在 shell 中运行,在 Linux 上默认为/ bin/sh -c,在 Windows 上默认为 cmd / S / C

    • RUN ["executable", "param1", "param2"]exec 形式)

    The RUN instruction will execute any commands in a new layer on top of the current image and commit the results. The resulting committed image will be used for the next step in the Dockerfile.

    RUN 指令将在当前镜像顶部的新层中执行所有命令,并提交结果。生成的提交镜像将用于 Dockerfile 中的下一步。

    Layering RUN instructions and generating commits conforms to the core concepts of Docker where commits are cheap and containers can be created from any point in an image’s history, much like source control.

    分层运行 RUN 指令并生成提交符合 Docker 的核心概念,在 Docker 上,提交很廉价,并且可以从镜像历史记录的任何位置创建容器,就像源代码控制一样。

    The exec form makes it possible to avoid shell string munging, and to RUN commands using a base image that does not contain the specified shell executable.

    exec 形式可以避免破坏 shell 字符串,并可以使用不包含指定 shell 可执行文件的基础镜像执行 RUN 命令。

    The default shell for the shell form can be changed using the SHELL command.

    可以使用 SHELL 命令更改 sh​​ell 格式的默认 shell。

    In the shell form you can use a (backslash) to continue a single RUN instruction onto the next line. For example, consider these two lines:

    shell 格式中,您可以使用 (反斜杠)将一条 RUN 指令继续到下一行。例如,考虑以下两行:

    RUN /bin/bash -c 'source $HOME/.bashrc; 
    echo $HOME'
    

    Together they are equivalent to this single line:

    它们在一起等效于以下这一行:

    RUN /bin/bash -c 'source $HOME/.bashrc; echo $HOME'
    

    To use a different shell, other than ‘/bin/sh’, use the exec form passing in the desired shell. For example:

    要使用 /bin/sh 以外的其他 shell,请使用 exec 形式传入所需的 shell。例如:

    RUN ["/bin/bash", "-c", "echo hello"]
    

    Note

    The exec form is parsed as a JSON array, which means that you must use double-quotes (“) around words not single-quotes (‘).

    注意

    exec 形式被解析为 JSON 数组,这意味着您必须使用双引号(")而不是单引号(')来包围单词。

    Unlike the shell form, the exec form does not invoke a command shell. This means that normal shell processing does not happen. For example, RUN [ "echo", "$HOME" ] will not do variable substitution on $HOME. If you want shell processing then either use the shell form or execute a shell directly, for example: RUN [ "sh", "-c", "echo $HOME" ]. When using the exec form and executing a shell directly, as in the case for the shell form, it is the shell that is doing the environment variable expansion, not docker.

    shell 格式不同,exec 格式不调用命令外壳程序。这意味着不会进行常规的外壳处理。例如,RUN [ "echo", "$HOME" ] 不会在 $HOME 上进行变量替换。如果要进行 shell 处理,则可以使用 shell 形式或直接执行 shell,例如: RUN [ "sh", "-c", "echo $HOME" ]。当使用 exec 格式并直接执行 shell 时,是由 shell 进行环境变量扩展,而不是 docker。

    Note

    In the JSON form, it is necessary to escape backslashes. This is particularly relevant on Windows where the backslash is the path separator. The following line would otherwise be treated as shell form due to not being valid JSON, and fail in an unexpected way:

    RUN ["c:windowssystem32	asklist.exe"]
    

    The correct syntax for this example is:

    RUN ["c:\windows\system32\tasklist.exe"]
    

    注意

    JSON 格式中,必须转义反斜杠。这在 Windows 中特别有用,在 Windows 中反斜杠是路径分隔符。由于无效的 JSON,以下行否则将被视为 shell 形式,并以意外的方式失败:

    RUN ["c:windowssystem32	asklist.exe"]
    

    此示例的正确语法为:

    RUN ["c:\windows\system32\tasklist.exe"]
    

    The cache for RUN instructions isn’t invalidated automatically during the next build. The cache for an instruction like RUN apt-get dist-upgrade -y will be reused during the next build. The cache for RUN instructions can be invalidated by using the --no-cache flag, for example docker build --no-cache.

    在下次构建期间,RUN 指令的缓存不会自动失效。诸如 RUN apt-get dist-upgrade -y 之类的指令的缓存将在下一次构建中重用。可以通过使用 --no-cache 标志来使 RUN 指令的缓存无效,例如 docker build --no-cache

    See the Dockerfile Best Practices guide for more information.

    有关更多信息,请参阅 Dockerfile 最佳实践指南

    The cache for RUN instructions can be invalidated by ADD and COPY instructions.

    RUN 指令的缓存可以通过 ADDCOPY 失效。

    示例

    Dockerfile 文件

    FROM busybox
    ENV name=jiangbo
    RUN echo $name
    RUN echo "---------------"
    RUN ["/bin/sh","-c","echo $name"]
    

    构建结果

    [root@master env]# docker build . --no-cache
    Sending build context to Docker daemon  3.584kB
    Step 1/5 : FROM busybox
     ---> dc3bacd8b5ea
    Step 2/5 : ENV name=jiangbo
     ---> Running in eee44fef26f6
    Removing intermediate container eee44fef26f6
     ---> 947038c832dc
    Step 3/5 : RUN echo $name
     ---> Running in 26e9d42ced2a
    jiangbo
    Removing intermediate container 26e9d42ced2a
     ---> a55b1d062caa
    Step 4/5 : RUN echo "---------------"
     ---> Running in 2b3455b3b565
    ---------------
    Removing intermediate container 2b3455b3b565
     ---> 314567362777
    Step 5/5 : RUN ["/bin/sh","-c","echo $name"]
     ---> Running in 7ebe6c03686d
    jiangbo
    Removing intermediate container 7ebe6c03686d
     ---> 2c6b18b8be36
    Successfully built 2c6b18b8be36
    [root@master env]#
    

    总结

    介绍了 Dockerfile 中 RUN 指令的使用。

  • 相关阅读:
    自写简单弹出框
    eclipse中debug模式不能启动运行,run运行模式却能启动运行!
    事务特性简单理解
    Java虚拟机4:内存溢出
    Java虚拟机3:常用JVM命令参数
    Java虚拟机2:Java内存区域及对象
    Eclipse技巧
    js常用的原生方法
    JavaScript调试小技巧
    html 锚点的使用
  • 原文地址:https://www.cnblogs.com/jiangbo44/p/14057377.html
Copyright © 2020-2023  润新知