Dockerfile COPY指令 语法解析
使用dockerfile
创建镜像时,肯定会涉及到文件复制、文件下载等操作,这时需要COPY
指令来完成。
COPY 语法
COPY [--chown=<user>:<group>] <src>... <dest>
COPY [--chown=<user>:<group>] ["<src>",... "<dest>"]
COPY 语义
· 第二种形式要求路径包括空格。
· --chown
仅支持dockerfile
构建Linux
容器,Windows
容器并不适用。由于Linux
和Windows
中的用户和用户组不同,因此使用/etc/passwd
和/etc/group
将用户和组名称转换为ID时限制了此功能仅适用于基于Linux操作系统的容器。
· COPY
指令从复制文件、目录到镜像文件系统的。
· 可以指定多个资源,但如果它们是文件或目录,则它们的路径被解释为相对于构建上下文的源。
· 每个可以包含通配符,匹配将使用Go
语言的filepath.Match
规则进行。例如:
1) *配合任意多个任意字符,匹配hom
开头的任意文件。
ADD hom* /mydir/
2) ?用于匹配单个字符,匹配home.txt
、homs.txt
等等文件。
ADD hom?.txt /mydir/
· 是一个绝对路径或者相对于WORKDIR
的路径,将被复制到目标容器中。例如:
1) 的值是:/relativeDir/
。
COPY test.txt relativeDir/
2) 的值是:绝对路径/absoluteDir/
。
COPY test.txt /absoluteDir/
· 当复制文件或目录包含特殊字符(例如:[
、]
),需要进行转义。
1) 如果为arr[0].txt
,则需进入如下转义:
COPY arr[[]0].txt /mydir/
· 除非可选的--chown
标志指定给定的用户名、组名或UID
/GID
组合来请求复制内容的特定所有权,否则所有新文件和目录都将使用UID
和GID
为0创建。--chown
标志的格式允许username
和groupname
字符串,也可以是任意组合的整数UID
和GID
。提供没有groupname
的用户名或没有GID
的UID
将使用与GID
相同的数字UID
。如果提供了用户名或组名,容器root
文件系统的/etc/passwd
和/etc/group
文件将分别用于执行从名称到整数UID
或GID
的转换。
ADD --chown=55:mygroup files* /somedir/
ADD --chown=bin files* /somedir/
ADD --chown=1 files* /somedir/
ADD --chown=10:11 files* /somedir/
· 如果容器root
文件系统不包含/etc/passwd
或/etc/group
文件,并且--chown
标志中使用了用户名或组名,则~操作将失败。使用数字标识不需要查找,也不依赖于容器根文件系统内容。
· COPY
遵循以下规则:
1) 路径必须在构建的上下文中;不能复制../something/something
,因为docker
构建的第一步是将上下文目录(和子目录)发送到docker
守护进程。
2) 如果是一个目录,复制目录的整个内容,包括文件系统元数据。目录本身不被复制,只复制其内容。
3) 如果是任何其他类型的文件,则单独复制它及其元数据。在这种情况下,如果以一个斜杠/
结尾,它将被视为一个目录,的内容将写入/base
()。
4) 如果直接或由于使用通配符指定了多个资源,则必须是一个目录,并且必须以斜杠/
结尾。
5) 如果没有以尾随斜杠结尾,它将被视为常规文件,的内容将写入。
6) 如果不存在,则会连同路径中所有丢失的目录一起创建。
COPY 示例
· 指定为带通配符文件,指定绝对目录。
1) 进入/securitit/dockerfile/copy
目录(根据个人选择,这是本文使用的目录),新增redis.conf
、nginx.conf
和keepalived.conf
,用于dockferfile
。
2) 进入/securitit/dockerfile/
目录,创建dockerfile
文件。
FROM nginx
MAINTAINER Securitit
COPY /copy/*.conf /securitit/
CMD /bin/bash
3) 执行如下的构建命令,基于dockerfile
构建镜像。
docker build -f /securitit/dockerfile/dockerfile -t securitit-nginx-copy:1.0.0.1 .
4) 查看镜像信息。
docker images
5) 指定通过dockerfile
生成的镜像启动容器。
docker run --name securitit-nginx-copy -it -d -p 80:80 securitit-nginx-copy:1.0.0.1
6) 查看容器信息。
docker ps -a
7) 进入容器,确认文件是否已添加到容器内/securitit/
目录下。
从结果可见,redis.conf
、nginx.conf
和keepalived.conf
已从宿主机的/securitit/dockerfile/copy/
目录下复制到了容器/securitit/
目录下。
总结
dockerfile
指令中,COPY
和ADD
非常相似,实现的功能也十分接近。ADD
相比COPY
,做了功能增强,可以’完成压缩文件解压并添加到镜像中’和’从URL下载文件到镜像中’。COPY
是精简版的ADD
指令,如果可以熟练的使用ADD
指令,那么COPY
指令其实已无太大用处。
若文中存在错误和不足,欢迎指正!
Dockerfile COPY指令 语法解析相关推荐
- Dockerfile ARG指令 语法解析
无论何种编程语言或脚本中,都不可避免的会应用到变量.dockerfile中使用ARG来定义变量,本文来对ARG指令定义变量进行解析. ARG 语法: ARG <name>[=< ...
- Dockerfile RUN指令 语法解析
Docker通过dockerfile创建镜像时,RUN和CMD是相当重要的命令,本文对这RUN指令进行解析. RUN 语法 # shell形式,命令在shell中运行,默认情况下,Linux是 ...
- Dockerfile ENV指令 语法解析
某些应用场景下,需要对Dokcer镜像加入环境变量,这时需要ENV指令.本文本来具体对ENV指令进行解析. ENV 语法 ENV <key>=<value> ... ...
- Dockerfile ENTRYPOINT指令 语法解析
系列博文之前讲解过RUN和CMD,其中CMD可以作为容器启动时的默认命令使用,而ENTRYPOINT是位于CMD之上的命令,同样可以可以设置容器启动时的入口点,可以使用ENTRYPOINT做许多系 ...
- Dockerfile配置指令详解
Dockerfile配置指令详解 一.FROM 二.RUN 三.CMD 四.EXPOSE 五.ENV 六.ADD 七.COPY 八.ENTRYPOINT 九.VOLUME 十.USER 十一.WORK ...
- Dockerfile文件万字全面解析
Dockerfile是一个文本文件,包含一些Docker指令.执行docker build,Docker就会执行Dockerfile里面的指令,来自动创建镜像. 用法 Dockerfile里面的指令可 ...
- dockerfile 执行原理_DockerFile解析
一.简介 Dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本 构建三步: DockerFile文件 ==> docker build ==> dock ...
- Dockerfile常用指令
FROM FROM指令是最重要的一个并且必须为Dockerfile文件开篇的第一个非注释行,用于为镜像文件构建过程指定基础镜像,后续的指令运行于此基础镜像提供的运行环境 这个基础镜像可以是任何可用镜像 ...
- Boost学习之语法解析器--Spirit
Boost.Spirit能使我们轻松地编写出一个简单脚本的语法解析器,它巧妙利用了元编程并重载了大量的C++操作符使得我们能够在C++里直接使用类似EBNF的语法构造出一个完整的语法解析器(同时也把C ...
最新文章
- 教你如何处理Nginx禁止ip加端口访问的问题
- WEB文档在线预览解决方案
- tp剩余未验证内容-8
- html ajax提交表单实例,Ajax提交表单并接收json实例代码
- Swagger+AutoRest 生成web api客户端(.Net)
- [CQOI2016]手机号码 数位DP
- a commit git 参数是什么意思_深入理解Git - 一切皆commit
- c++ 共享内存_关于Linux共享内存的实验 [二] - 原因
- 32路视频光端机性能指标及视频特性介绍
- Atom Latex Settings
- IDA动态调试Android的DEX文件
- 区块链共识机制优缺点对比都是什么
- wordpress插件之baidu-sitemap-generator
- python处理时间的标准函数库_使用Python的datetime库处理时间(RPA流程)
- 简单易学!一步步带你理解机器学习算法——马尔可夫链蒙特卡罗(MCMC)
- python科研向论文检索篇——提取PDF文字以供全文信息检索
- 月薪达到1万的web前端工程师,都会些什么呢?(附路线资料)
- 各种加密模式在TLS协议中的运用 2 (AEAD:CCM模式)
- 博士应该采取什么策略读文献?
- ctf web3 30 flag就在这里快来找找吧http://123.206.87.240:8002/web3