Docker数据容器卷的建立备份和恢复

数据卷容器html

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

建立数据卷容器dbdata
docker run -v /dbdata:/dbdata --name dbdata centosubuntu

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

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

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

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

备份容器中的数据卷到本地
[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.fileit

恢复 class

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

进行恢复
建立个带有数据卷的容器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 dbdatatest.file

相关文章
相关标签/搜索