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指令将在当前图像顶部的新层中执行所有命令,并提交结果。生成的提交图像将用于中的下一步Dockerfile。
分层RUN指令和生成提交符合Docker的核心概念,在Docker上,提交很便宜,并且可以从映像历史记录的任何位置创建容器,就像源代码控制一样。
exec形式可以避免破坏shell字符串,并可以RUN使用不包含指定shell可执行文件的基本映像进行命令。
可以使用以下SHELL命令更改外壳程序表单的默认外壳程序。
在shell形式中,您可以使用\(反斜杠)将一条RUN指令继续到下一行。例如,考虑以下两行:
RUN /bin/bash -c 'source $HOME/.bashrc ;\ echo $HOME'
它们在一起等效于以下这一行:
RUN /bin/bash -c 'source $HOME/.bashrc ; echo $HOME'
注意:要使用'/ bin / sh'以外的其他shell,请使用exec形式传入所需的shell。例如,RUN ["/bin/bash", "-c", "echo hello"]
注意:exec表单被解析为JSON数组,这意味着您必须“在单词而非单引号()周围使用双引号(‘)。
注意:与shell窗体不同,exec窗体不会调用命令shell。这意味着不会进行常规的外壳处理。例如,RUN [ "echo", "$HOME" ]将不会对进行变量替换$HOME。如果要进行shell处理,则可以使用shell形式或直接执行shell,例如:RUN [ "sh", "-c", "echo $HOME" ]。
注意:在JSON格式中,必须转义反斜杠。这在Windows中特别有用,在Windows中反斜杠是路径分隔符。由于无效的JSON,以下行否则将被视为shell形式,并以意外的方式失败:RUN ["c:\windows\system32\tasklist.exe"]
此示例的正确语法为: RUN ["c:\\windows\\system32\\tasklist.exe"]
RUN下一次构建期间,指令缓存不会自动失效。类似指令的缓存RUN apt-get dist-upgrade -y将在下一个构建中重用。RUN可以使用--no-cache标志使指令的缓存无效,例如docker build --no-cache。
有关更多信息,请参见《 Dockerfile最佳实践》指南。
RUN指令的高速缓存可以被ADD指令无效。有关详情,请参见下文。