第六章 数据管理
容器中管理数据主要有两种方式:
* 数据卷(Data Volumes)
* 数据卷容器(Data Volume Container是)
6.1 数据卷
数据卷是一个可供容器使用的特殊目录,它绕过文件系统。
特性:
* 数据卷可在容器间共享和重用。
* 对数据卷的修改会立即生效。
* 对数据卷的更新,不影响镜像。
* 卷会一直存在,直到没有容器使用。
数据卷的使用,类似于Linux下对目录或文件进行mount操作。
在容器内创建一个数据卷
用docker run命令时,使用 -v 标记可在容器内创建一个数据卷。多次使用-v标记,可创建多个数据卷。
挂载一个主机目录作为数据卷
使用 -v 标记也可以指定挂载一个本地已有目录到容器中去作为数据卷。
本地目录的路径必须是绝对路径,若目录不存在,Docker会自动创建。
Docker挂载数据卷的默认权限是读写(rw),用户也可以通过ro指定为只读。
挂载一个本地主机文件作为数据卷
-v 标记也可从主机挂载单个文件到容器中作为数据卷。
注意:若直接挂载一个文件,使用文件编辑工具,包括vi或sed –inplace时,可能导致文件inode改变。所以推荐的方式是直接挂载文件所在的目录。
6.2 数据卷容器
容器间共享一些持续更新的数据,最简单的方式是使用数据卷容器。
数据卷容器就是一个普通的容器,专门用于提供数据卷供其他容器挂载。
使用方法:
1. 创建一个数据卷容器 dbdata,并在其中创建一个数据卷挂载到 /dbdata:
$ sudo docker run -it -v /dbdata --name dbdata ubuntu
2. 在其他容器中使用 –volumes-from 来挂载dbdata容器中的数据卷。多次使用–volumes-from参数来从多个容器挂载多个数据卷。还可以从其他已挂载数据卷的容器来挂载数据卷。
如创建db1和db2两个容器,并从dbdata容器挂载数据卷:
$ sudo docker run -it --volunmes-from dbdata --name db1 ubuntu
$ sudo docker run -it --volunmes-from dbdata --name db2 ubuntu
此时,容器db1、db2都挂载同一个数据卷到相同的/dbdata目录,三个容器任何一方在该目录下的写入,其他容器都可以看到。
要删除一个容器卷,必须在删除最后一个还挂载它的容器时显式使用 docker rm -v 命令来指定同时删除关联的容器。
6.3 利用数据卷容器迁移数据
备份
使用下面命令来备份dbdata数据卷容器内的数据卷:
$ sudo docker run --volumes-from dbdata -v $(pwd):/backup --name workder ubuntu tar cvf /backup/backup.tar /dbdata
分析:
首先使用Ubuntu镜像创建一个容器worker。使用--volumes-from dbdata
参数来让worker容器挂载dbdata容器的数据卷;使用-v $(pwd):/backup
参数来挂载本地的当前目录到worker容器的 /backup 目录。
worker容器启动后,使用了tar cvf /backup/backup.tar /dbdata
命令将 /dbdata 下内容备份为容器内 /backup/backup.tar,即宿主主机当前目录下的backup.tar。
恢复
恢复数据到一个容器,首先创建一个带有数据卷的容器dbdata2,然后创建另一个新的容器,挂载dbdata2的容器,并使用untar解压备份文件到所挂载的容器卷即可:
$ sudo docker run -v /dbdata --name dbdata2 ubuntu /bin/bash
$ sudo docker run --volumes-from dbdata2 -v $(pwd):/backup busybox tar xvf /backup/backup.tar