Docker学习之路:数据管理

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

总结:数据管理在docker中很重要,宝贵的数据在进行操作时,可能会存在丢失,所有一些时候数据的存储只要其他条件支撑,docker允许配置和安装共享存储,例如iSCSI,NFS或FC.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值