docker技术学习总结(4)—— 数据管理

容器中管理数据有两种方式:

  • 数据卷(Data Volumes)
  • 数据卷容器(Data Volume Dontainers)

1,数据卷

数据卷是一个可供容器使用的特殊目录,他绕过文件系统,提供很多有用的特性:

  • 可以在容器之间共享和重用
  • 对数据卷的修改会立刻生效
  • 对数据卷的更新不影响镜像
  • 一直存在直到没有容器使用

数据卷的使用类型linux下对目录或文件进行mount操作。

  • 在容器中创建一个数据卷

在使用docker run命令的时候,使用-v标记可以在容器内创建一个数据卷,多次使用-v可以创建多个数据卷。

栗子:使用training/webapp 镜像创建一个web容器,并创建一个数据卷挂载到容器的/webapp目录:

docker run -d -P --name web -v /webapp training/webapp python app.py,其中-P是允许外部访问容器需要暴漏的端口。

  • 挂在一个主机目录作为数据卷

使用-v标记也可以指定挂载一个本地目录到容器中作为数据卷:

docker run -P -d --name web2 -v /src/webapp:/opt/webapp training/webapp python app.py,加载主机的/src/webapp目录到容器的/opt/webapp目录:

这个功能在进行测试的时候非常方便,可以在本地目录放一些文件或程序,然后在容器中使用。

  • 挂载一个主机文件作为数据卷

-v也可以指定一个本地文件挂载到容器中作为数据卷:

docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu /bin/bash,这样就可以记录在容器内输入过的历史命令了。

2,数据卷容器

如果需要多个容器共享一些经常更新的数据,最简单的方式就是使用数据卷容器。数据卷容器就是一个普通的容器,专门提供数据卷给其他容器挂载:

首先,创建一个数据容器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目录。三个容器任何一个在该目录写入,其他容器都可以看到。

3,利用数据卷容器迁移数据

  • 备份

使用下面到命令来备份dbdata数据卷容器到数据卷:

docker run --volumes-from dbdata -v /bk:/bk --name worker ubuntu tar cvf /bk/bk.tar /dbdata

  • 恢复

首先创建一个带有数据卷到容器:

docker run -it -v /dbdata --name dbdata2 ubuntu /bin/bash

然后创建一个新的容器,挂载dbdata2容器,将bk.tar解压到容器中:

docker run --volumes-from dbdata2  -v /bk:/bk ubuntu tar xvf /bk/bk.tar



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值