什么是数据卷容器
命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据卷的容器,就叫做数据卷容器
关于数据卷和数据卷容器的不同,如下图所示,数据卷容器挂载了一个本地的文件或者目录,其他的容器通过连接这个数据卷容器来共享数据
挂载数据卷容器的方法
$docker run --volumes-from [CONTAIRE NAME]
[CONTAIRE NAME]是已经挂载了数据卷的容器的名字
实例:
已有一个挂载了数据卷的容器dvt3,有两个数据卷datavolume1和datavolume2
新启动一个容器并挂载dvt3数据容器
docker run -it --name dvt5 --volumes-from dvt3 ubuntu /bin/bash
上图可以看到使用数据卷容器可以使不同容器共享数据,同时不需要使用者确切的连接到宿主机的目录或文件,这个对于多用户的情况下十分重要。
使用 docker inspect --format="{{.Mounts}}" dvt5查看dvt5容器的数据卷信息
如果我们删除掉数据卷容器会怎么样?来试试
docker rm dvt3
删除后我们进入到dvt5中,发现数据卷还在,之前博客说过,数据卷独立与容器,生命周期不随着容器的消亡而结束,其实,数据容器只是起到数据卷信息的传递。
数据卷的备份和还原
如下面两图所示
- 数据备份方法
docker run --volumes-from [container name] -v [localhostfile]:/backup ubuntu tar cvf /backup/backup.tar [container data volume]
解释一下,container name是要备份数据卷的容器的名字,pwd是指宿主机目录
举例:
运行一个容器dvt6将dvt5容器的数据卷备份
docker run --volumes-from dvt5 -v /usr/local/Docker/backup:/backup --name dvt6 ubuntu tar cvf /backup/dvt5.tar /datavolume1
此时数据已经备份好了
同时我们也可以还原数据
docker run -volumes-from [container name] -v $[local file]:/backup ubuntu tar xvf /backup/backup.tar [container data volume]