容器中数据管理主要有两种方式:
数据卷(Data Volumes):容器内数据直接映射到本地主机环境;
数据卷容器( Data Volume Containers)使用特定的容器维护数据卷。
数据卷
数据卷是一个可供容器使用的特殊目录,他将主机操作系统目录直接映射进容器,类似于Linux中的mount操作。
数据卷可以提供很多有用的特性,如下:
* 数据卷可以在容器之间共享和重用,容器间传递数据变的高效方便;
* 对数据卷内数据的修改会立马生效,无论是容器内操作还是本地操作;
* 对数据卷的更新不影响镜像,解耦了应用和数据;
* 卷会一直存在,知道没有容器使用,可以安全地卸载它。
1、在容器内创建一个数据卷
在用docker run 命令的时候,使用-v标记可以在容器内创建一个数据卷。多次重复使用-v标记可以创建多个数据卷。
下面使用 training/webapp镜像创建一个web容器,并创建一个数据卷挂载到容器的/webapp目录:
docker run -d -P –name web -v /webapp training/webapp python app.py
2、挂载主机目录作为数据卷(推荐方式)
docker run -d -P –name web -v /src/webapp:/opt/webapp training/webapp python app.py
加载主机的/src/webapp目录到容器的/opt/webapp目录
docker run -d -P –name web -v /src/webapp:/opt/webapp:ro training/webapp python app.py
设置为只读
3、挂载一个本地主机文件作为数据卷
docker run -d -P –name web -v ~/.bash_history:/.bash_history ubuntu /bin/bash
数据卷容器
首先创建一个数据卷容器dbdata,并在其中创建一个数据卷挂载到/dbdata:
docker run -it -v /dbdata –name dbdata ubuntu
然后,可以在其他容器中使用-volumes-from来挂载dbdata容器中的数据卷,例如创建db1和sb2两个容器,并从dbdata容器挂载数据卷:
docker run -it -volumes-from dbdata –name db1 ubuntu
docker run -it -volumes-from dbdata –name db2 ubuntu
利用数据卷容器来迁移数据
可以利用数据卷对其中的数据卷进行备份、恢复,以实现数据的迁移。
1、备份
docker run –volumes-from dbdata -v
(pwd):/backup–nameworkerubuntutarcvf/backup/backup.tar/dbdata这个命令稍微有点复杂,具体分析一下。首先利用ubuntu镜像创建了一个容器worker。使用–volumes−fromdbdata参数来让worker容器挂载dbdata容器的数据卷(即dbdata数据卷);使用−v
(
p
w
d
)
:
/
b
a
c
k
u
p
–
n
a
m
e
w
o
r
k
e
r
u
b
u
n
t
u
t
a
r
c
v
f
/
b
a
c
k
u
p
/
b
a
c
k
u
p
.
t
a
r
/
d
b
d
a
t
a
这
个
命
令
稍
微
有
点
复
杂
,
具
体
分
析
一
下
。
首
先
利
用
u
b
u
n
t
u
镜
像
创
建
了
一
个
容
器
w
o
r
k
e
r
。
使
用
–
v
o
l
u
m
e
s
−
f
r
o
m
d
b
d
a
t
a
参
数
来
让
w
o
r
k
e
r
容
器
挂
载
d
b
d
a
t
a
容
器
的
数
据
卷
(
即
d
b
d
a
t
a
数
据
卷
)
;
使
用
−
v
(pwd):backup 参数来挂载本地的当前目录到worker容器的/backup目录。
worker容器启动后,使用了tar cvf /backup/backup.tar /dbdata命令将/dbdata下内容备份为容器内的/backup/backup.tar,即宿主主机当前目录下的buckup.tar。
2、恢复
首先创建一个带有数据卷的容器dbdata2:
docker run -v /dbdata –name dbdata2 ubuntu /bin/bash
sudo docker run -itd -v /data –name data1 c9fc7f8eec37
然后创建另一个新的容器,挂载dbdata2的容器,并使用untar解压备份文件到所挂载的容器卷中:
docker run –volumes-from dbdata2 -v $(pwd):/backup busybox tar xvf /backup/backup.tar