docker的数据管理方式有两种
- 数据卷(Data Volumes) 容器内数据直接映射到本地主机环境
- 数据卷容器(Data Volume Containers) 使用的特定容器维护数据卷
数据卷操作
#在容器中创建一个数据卷,使用-v指定
docker run -d -P --name web1 -v /webapp training/webapp python app.py
#查看挂载的数据卷
docker inspect web1
# 也可以挂载一个本地的目录到容器中
docker run -d -P --name web2 -v /src/webapp:/webapp training/webapp python app.py
#查看挂载的数据卷
docker inspect web
#Docker卷默认以读写模式安装,但您也可以将其设置为以只读方式挂载,加上ro
docker run -d -P --name web3 -v /src/webapp:/webapp:ro training/webapp python app.py
数据卷容器操作
如果要在容器之间共享某些持久性数据,则最好创建一个命名的数据卷容器,然后从这个容器中装入数据。
#创建一个数据卷容器dbdata,然后在容器中创建一个数据卷挂载到/dbdata
docker run -dit -v /dbdata --name dbdata ubuntu
#然后在其他容器中使用--volumes-from来挂载dbdata容器中的数据卷
docker run -dit --volumes-from dbdata --name dbdata1 ubuntu
docker run -dit --volumes-from dbdata --name dbdata2 ubuntu
在这样的情况下,三个容器中任意一个容器对/dbdata 有了改动,那么三个容器都可以看到,如果删除挂载卷容器,包括最初的dbdata容器或接下来的容器dbdata1和dbdata2,卷将不会被删除。要从磁盘中删除卷,必须在删除最后一个挂载/dbdata的容器时显式调用docker rm -v 来指定同时删除关联的容器,这就可以在容器之间升级或有效迁移数据卷。
利用数据卷容器来迁移数据
备份
当前的命令是运行一个名字为worker的ubuntu容器,并将dbdata的卷挂载到/worker的backup目录,然后当worker容器启动的时候将/dbdata打包成tar以用作备份,备份之后就可以在主机的当前目录看到backup.tar了
docker run --volumes-from dbdata -v $(pwd):/backup --name worker ubuntu tar cvf /backup/backup.tar /dbdata
恢复
创建一个带数据卷的容器,此时的数据卷中并没有任何的数据
docker run -dit -v /dbdata --name dbdata2 ubuntu
接着创建另一个容器,挂载dbdata2的容器,并使用untar解压备文件到所挂载的容器卷中,此时会发现之前空空如也的dbdata2中的目录/dbdata已经出现了之前在dbdata数据卷容器中中的/dbdata中的数据
docker run --volumes-from dbdata2 -v $(pwd):/backup busybox tar xvf /backup/backup.tar