前言:管理 Docker容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes
Containers ) 。
1.数据卷
数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的 mount操作。
实例:将宿主机目录 /var/www 分别挂载到c1 c2容器中的 /data1,/data2
(1)创建两个容器 并指定挂载点
docker run -itd -v /var/www:/data1 --name c1 centos:7 bash
docker run -itd -v /var/www:/data2 --name c2 centos:7 bash
(2)在宿主机目录写入数据
echo "this is test fuck web" > index.html
(3)另外开两个终端,分别登陆c1 c2容器,并查看挂载点目录里的文件
挂载成功的同时,而且还能实现文件共享,就比如我在c2 终端上创建一个文件 ,c1 宿主机上同样能看到
2.数据卷容器
如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
(1)先创建一个数据卷容器
docker run -itd --name v1 -v /data1 -v /data2 centos:7 bash
#有data1 data2 两个挂载点目录
(2)再创建一个容器 挂载到 数据卷容器上
docker run -itd --name v2 --volumes-from v1 centos:7 bash
(3)另外开两个终端 分别登陆v1 v2 容器,查看挂载点