
3.然后此时在三个容器中任何一方在/dbdata目录下的写入,其他容器中都可以看到。

在图中,在dbdata容器中创建testfile文件并写入”dbdata container write!”,然后在db1容器中查看并写入“db1 container write!”,然后在db2容器中查看并写入“da2 container write!”,最后回到dbdata容器中查看。
4.然后还可以通过多个–volumes-from来挂载多个数据卷,然后还给出了备份和恢复的方法,网上一搜一大把。
3.为什么不用数据卷容器?
在看到许许多多关于数据卷容器的文章,并且都是大同小异。然后我想了想发现并没有使用数据卷的必要性(或许是我想的不够周全)。
上面提到数据卷容器用来在多个容器中共享数据,但是在明明可以通过挂载一个相同的本地目录就能实现该方法。比如说在第一步中创建的my-vol数据卷,我可以将其同时挂载到db3和db4容器中。

在图中,我将my-vol数据卷挂载到了db3和db4中,然后在其中能够找到之前的数据文件,并且在db4容器中对testfile文件进行写入操作,在db3中容器中也可以查看。
那么也就是说,我同样的可以通过挂载一个数据卷就可以实现多个容器中的数据共享,并且在主机的目录中添加的文件,在所有的容器中也能够查看。如果备份的话直接在主机本地将文件夹进行拷贝即可,岂不是更方便。
4.为什么使用数据卷容器?
但是数据卷容器还有一个作用比较不错,那就是可以用来指定挂载本地目录,在第一点中我们创建一个名为my-vol的数据卷,该数据卷在本地存放的目录为:/var/lib/docker/volumes/my-vol/_data,可以看出这个名字很长不方便操作,可以通过数据卷容器来解决该问题。
比如我在主机上创建了一个专门用来存放主机和容器进行文件交互的目录,也就是说以后我想给容器中传输什么文件了,我直接将文件拷贝到该目录下即可:

我在官方文档中并没有发现使用docker volume create 创建数据卷时可以指定volume对应的本地目录的命令(或许是我看的不够多)。
但是我就是想要用/usr/local/datadb 这个目录该怎么办?此刻数据卷容器的作用就出来了,可以通过创建一个数据卷容器,并且将该目录挂在到数据卷容器上即可:

在图中,我创建了一个所谓的数据卷容器,并且使用-v参数,将刚才主机的/usr/local/datadb目录挂载进去,然后在容器中创建文件testfile并写入“HAHAHAHA”,在主机上进行查看。










