许多同学不知道Dockerfile应该如何写,不清楚Dockerfile中的指令分别有什么意义,能达到什么样的目的,接下来我将在容器化专栏中详细的为大家解释每一个指令的含义以及用法。
专栏订阅传送门https://blog.csdn.net/qq_38220908/category_11989778.html
指令不区分大小写 。但是,按照惯例,它们应该是大写的,以便更容易地将它们与参数区分开来。(引用至官方文档>>>)
使用Dockerfile构建Springboot项目
Docker官方文档 - ADD
Dockerfile命令详解之 FROM
Dockerfile命令详解之 ARG
Dockerfile命令详解之 COPY
ADD [--chown=:] ...
或者
ADD [--chown=:] ["",... ""]
:宿主机(这里指的是安装有Docker引擎的那台服务器)文件所在路径或远程文件url,如果是宿主机本地文件,填写的路径可以是相对路径(相对路径,则是目标文件与构建上下文的相对路径)。
:指的是容器内的路径,如果是相对路径,则是相对于WORKDIR的路径
注意:
1、--chown选项只适用于构建liunx类型的容器,不适用于windows类型的容器,因为用户组和所有权的概念不能在liunx和windows之间做转换。
2、第二种命令格式主要用于路径中包含空格的情况!
3、
4、
5、
6、如果
7、复制多个文件时,
8、当
当ADD指令的
比如:我要将/usr/local/app下的所有jar文件复制到容器中的/app/build/目录下,我们可以这样写Dockerfile
FROM openjdk:11
WORKDIR /app
# 匹配以jar为后缀的文件
ADD app/*.jar build/
我们也可以通过?符号,匹配单个字符,比如使用指令 ADD boo?.txt /app/build ,就可以复制Dockerfile当前文件夹下 book.txt , boom.txt等等符合规则的文件。
注意:
如果文件中含有特殊字符,比如[或者]这样的字符,我们需要按照Golang的规则进行通配符的转换。比如文件arr[0].text 就需要写成ADD arr[[]0].txt /app/build/
文件是否被识别为可识别的压缩格式完全是基于文件的内容,而不是文件的名称。例如,如果一个空文件恰好以.tar.gz结尾,这将不会被识别为一个压缩文件,并且不会生成任何类型的解压缩错误消息,而只是将该文件复制到目的地。
ADD [--keep-git-dir=]
我们可以使用上面的命令格式,拉取GIT仓库中的文件,而不需要使用git clone的命令。
比如:
FROM alpine
ADD --keep-git-dir=true https://github.com/moby/buildkit.git#v0.10.1 /buildkit
--keep-git-dir=true表示保留.git目录。默认值为false。
拉取私有仓库的文件
FROM alpine
ADD [email protected]:foo/bar.git /bar
这个Dockerfile可以用docker build --ssh default来构建。
与COPY --link相同,ADD --link会将你复制的文件放在一个空目录中,并将此目录转换为一个独立的层,并链接到上一阶段的构建中。
比如:
FROM alpine
ADD --link /usr/local/app/*.jar /app/build/
就相当于:
FROM alpine
FROM scratch
ADD /usr/local/app/*.jar /app/build/
并且将构建出来的两层合并到一起。
使用ADD --link将重用之前生成的构建并合并到新层之上。这也意味着,当基本映像收到更新时,您可以轻松地重新设置映像的基础,而不必再次执行整个构建!!
一般来说推荐使用ADD --link,以提供更好的构建体验。
[1] 感谢大佬 @kenllf 的斧正