我的问题是关于文件从容器复制到主机的问题;我有一个Dockerfile,从源代码获取依赖项,编译构建工件,并运行可执行文件。我还想复制构建工件(在我的情况下,它是由sbt dist在……/target/ ',但我认为这个问题也适用于jar,二进制文件等。
Docker cp工作在容器上,而不是镜像上;我是否需要启动一个容器来获取一个文件?在一个脚本中,我尝试在后台以交互模式运行/bin/bash,复制文件,然后杀死容器,但这似乎很笨拙。有没有更好的办法?
另一方面,我想避免在运行docker save $IMAGENAME后解包一个.tar文件,只是为了得到一个文件(但这似乎是最简单的,如果是最慢的,目前的选项)。
我会使用docker卷,例如:
docker run -v hostdir:out $IMAGENAME /bin/cp/../blah.zip /out
但是我在OSX中运行boot2docker,我不知道如何直接写入我的mac主机文件系统(读写卷挂载在我的boot2docker虚拟机中,这意味着我不能轻松地共享一个脚本来从映像中提取blah.zip。想法吗?
第一个使用docker pull的docker映像
docker pull <IMG>:<TAG>
然后使用docker create命令创建一个容器,并将容器id存储为一个变量
img_id=$(docker create <IMG>:<TAG>)
现在,运行docker cp命令将docker容器中的文件夹和文件复制到主机上
docker cp $img_id:/path/in/container /path/in/host
一旦文件/文件夹被移动,使用docker rm删除容器
docker rm -v $img_id
docker cp $(docker create --name tc registry.example.com/ansible-base:latest):/home/ansible/.ssh/id_rsa ./hacked_ssh_key && docker rm tc
希望提供基于纯docker功能的一行解决方案(不需要bash)
编辑:容器甚至不需要在这个解决方案中运行
edit2:感谢@Jonathan Dumaine的——rm,所以容器将被删除后,我只是从来没有尝试过,因为它听起来不合逻辑,从某个地方复制的东西已经被前一个命令删除,但我尝试过,它工作
edit3:由于注释我们发现——rm没有像预期的那样工作,它不会删除容器,因为它从来没有运行过,所以我添加了删除创建的容器的功能(——name tc=temporary-container)
编辑4:出现了这个错误,似乎是docker中的一个错误,因为t在a-z中,而这在几个月前没有发生。
Error response from daemon: Invalid container name (t), only [a-zA-Z0-9][a-zA-Z0-9_.-] are allowed