利用Volume在主机和Docker容器文件传输的方法

2020-06-17 07:12:35易采站长站整理

之前写过一篇关于Docker容器和本机之间的文件传输。的文章,但是此方法相对比较繁琐一些,在查看了官方关于数据管理的文档之后发现利用volume来实现主机和容器的文件传输效率更高一点,其实也就是将本地的目录进行挂载到容器上,官方一共有三种方法:Manage data in Docker,

这里只介绍使用volume的操作:Use volumes

1.使用Volume在主机和容器之间传输文件。

在官方文档中可以看到使用如下命令即可创建一个volume:

Create a volume:


$ docker volume create my-vol

注意这个命令不是所有的docker版本都可以运行的:

The client and daemon API must both be at least 1.21 to use this command. Use the docker version command on the client to check your client and daemon API versions.

创建完成之后可以查看详细信息:


$ docker volume inspect my-vol

注意这个Mountpoint所对应的目录就是我们用来主机和容器进行文件传输的目录。

然后在使用run启动一个容器的时候就可以使用该volume:

可以看到通过-v命令将刚才创建的数据卷挂载到容器中的hostdata目录下了,这时候我们在容器中给hostdata目录下添加文件的时候,在主机的的/var/lib/docker/volumes/my-vol/_data中就可以看到了,同理在主机的该目录中添加文件,在容器的hostdata中也可以看到。

我将nginx这个文件复制到主机中用来交换的目录下,进入容器之后在hostdata的目录下也可以查看:

同样的在容器中将文件拷贝到hostdata目录下中,在主机的/var/lib/docker/volumes/my-vol/_data也能够使用查看。

在这里我在容器中创建一个文件testfile并向其中写入:This is container write!,然后回到主机进行查看,并在主机中使用vim向其中添加:“This is host write!”,并返回容器中进行查看。

2.使用数据卷容器。

我在有些地方看到有人使用数据卷容器来实现多个容器之间的数据共享,其过程是这样子的:

1.先创建一个数据卷容器dbdata,并在其中创建一个数据卷挂载到/bdata:

可以通过docker volume ls查看生成了一个随机名称的volume。

2.然后,可以在其他容器中使用–volumes-from来挂载dbdata容器中的数据卷,例如创建db1和db2两个容器,并从dbdata容器挂载数据卷: