数据卷容器

如果容器之间需要共享一些持续更新的数据,最简单的方式就是是用户数据卷容器,数据卷容器就是一种普通容器,专门提供数据卷供其它容器挂载使用。

创建数据卷容器dbdata docker run -v /dbdata:/dbdata --name dbdata centos

创建db1和db2两个容器,并使用--volumes-from挂载dbdata容器中的数据卷

docker run --volumes-from dbdata --name db1 centos docker run --volumes-from dbdata --name db1 centos

三个容器任何一个容器在该目录下写入,其他容器都能看见。

[root@localhost ~]# cd /dbdata/ [root@localhost dbdata]# ls [root@localhost dbdata]# touch index.html 在容器db1里查看 [root@localhost dbdata]# docker exec db1 ls 会看到有新建文件。

备份容器中的数据卷到本地 [root@localhost ~]# docker run --volumes-from dbdata -v $(pwd):/backup --name worker centos tar zcf /backup/backup.tar.gz /dbdata tar: Removing leading `/' from member names [root@localhost ~]# ls anaconda-ks.cfg backup.tar.gz [root@localhost ~]# tar xvf backup.tar.gz dbdata/ dbdata/test.file [root@localhost ~]# ls anaconda-ks.cfg backup.tar.gz dbdata [root@localhost ~]# ls dbdata/ test.file

恢复

删除容器中的而文件 [root@localhost ~]# docker exec dbdata rm dbdata/test.file [root@localhost ~]# docker exec dbdata ls dbdata

进行恢复 创建个带有数据卷的容器dbdata2 docker run -it -v /dbdata --name dbdata2 ubuntu /bin/bash

[root@localhost ~]# docker run --volumes-from dbdata2 -v $(pwd):/backup centos tar xvf /backup/backup.tar.gz dbdata/ dbdata/test.file

查看恢复的 [root@localhost ~]# docker exec dbdata2 ls dbdata test.file