容器中管理数据有两种方式:
- 数据卷(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