docker学习小实战(七)数据卷应用

数据卷是一个可供容器使用的特殊目录,它将主机操作系统目录直接映
射进容器
-v标记在容器内创建一个数据卷
加载主机的/ src/webapp目录到容器的/ opt/webapp目录。

docker run -d -P --name web -v /src/webapp:/opt/webapp training/webapp

在这里插入图片描述
Docker挂载数据卷的默认权限是读写(rw),只需加一个ro指定为
只读即可:

# docker run -d -P --name web -v /src/webapp:/opt/webapp:ro training/webapp

数据卷容器

如果我们需要在多个容器之间共享一些持续更新的数据,最简单的方式
是使用数据卷容器。
创建一个数据卷容器dbdata,并在其中创建一个数据卷挂载到/
dbdata目录

docker run -it -v /dbdata --name dbdata ubuntu

然后,可以在其他容器中使用–volumes-from来挂载dbdata容器中的数据
卷,例如创建db1和db2两个容器,并从dbdata容器挂载数据卷:

# docker run -it --volumes-from dbdata --name db1 ubuntu
# docker run -it --volumes-from dbdata --name db2 ubuntu

在这里插入图片描述
容器db1和db2都挂载同一个数据卷到相同的/ dbdata目录。三个容
器任何一方在该目录下的写入,其他容器都可以看到。

实验一下
我先加数据卷容器的数据卷里建立了一个test文件
在这里插入图片描述
在db1查看它是否存在
在这里插入图片描述
存在!实验成功。

利用数据卷容器来迁移数据
先备份

docker run --volumes-from dbdata --name worker ubuntu -v $(pwd):/backup  tar cvf /backup/backup.tar /dbdata

这个命令稍微有点复杂,具体分析一下。

  1. 利用ubuntu镜像创建一个容器worker。

  2. 使用–volumes-from dbdata参数来让worker容器挂载dbdata容
    器的数据卷(即dbdata数据卷);

  3. 使用-v$(pwd):/backup参数来挂载本地的当
    前目录到worker容器的/backup目录。

  4. worker容器启动后,使用了tar cvf/backup/backup.tar/dbdata命令来将/
    dbdata下内容备份为容器内的/ backup/backup.tar,即宿主主机当前目录下的backup.tar。
    但是当我这样运行出现了

在这里插入图片描述
路径出现了问题,采用绝对路径应该加一个大写的P,在cvf中加个P即可。
运行。
在这里插入图片描述
恢复数据
首先创建一个带有数据卷的容器dbdata2:
$ docker run -v /dbdata --name dbdata2 ubuntu /bin/bash
然后创建另一个新的容器,挂载dbdata2的容器,并使用untar解压备份文
件到所挂载的容器卷中:
$ docker run --volumes-from dbdata2 -v $(pwd):/backup busybox tar xvfP
/backup/backup.tar

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值