本节目录:
- 数据管理
- 数据卷
- 数据卷容器
- 备份、恢复、迁移数据卷
数据管理
本小节学习在 Docker 内部以及容器之间管理数据,主要方式:
- 数据卷(Data volumes)
- 数据卷容器 (Data volume containers)
数据卷
数据卷是一个提供一个或者多个容器使用的 特殊目录 它绕过 UFS ,可以提供很多有用的特性:
- 数据卷可以在容器之间共享和重用
- 对数据卷的更新可以立马生效
- 数据卷的更新不会影响镜像
- 数据卷默认一直存在,即使容器被删除
创建一个数据卷
在使用 docker run 命令,使用 -v 标记来创建一个数据卷并挂载到容器里。在一次 run 中多次使用可以挂载多个数据卷。
实例:
下面创建一个名为 web 的容器,并加装一个数据卷到容器的 /webapp
注意: 也可以在 Dockerfile 中使用 VOLUME 来添加一个或者多个新的卷到由该镜像创建的任意容器。
删除数据卷
数据卷是被设计用来持久化数据的,它的生命周期独立于容器,Docker 不会在容器被删除后自动删除数据卷,也不出现垃圾回收机制来处理没有任何容器引用的数据卷。如果需要在删除容器的同时移除数据卷。可以在删除命令加 -v
参数,docker rm -v 命令删除容器移除数据卷
挂载一个主机目录作为数据卷
-v 标记也可以指定挂载一个本地主机的目录到容器中去
上面的命令加载主机 /src/webapp 目录到容器的 /opt/webapp目录。
注意: Dockerfile 不支持这种用法,这是因为Dockerfile 是为了移植和分享用的。然而,不同操作系统的路径格式不一样,所以现在还不能支持
Docker 挂载数据卷默认权限是读写,用户也可以通过:ro指定为只读
|
|
加了 :ro 之后,就挂载为只读了
查看数据卷的具体信息
在输出的内容中找到其中和数据卷相关的部分
数据卷容器
如果你有一些持续更新的数据需要在容器之间共享,最好创建数据卷容器。专门提供数据卷为其他容器挂载的。
实例:创建 dbdata 数据卷容器
在其他容器中 使用 –volumns-from 来挂载dbdata 容器中的数据卷
注意:使用 –volumes-from 参数所挂载数据卷的容器自己并不需要保持在运行状态。
利用数据卷容器来备份、恢复、迁移数据卷
备份
|
|
创建一个挂载 dbdata 的容器,并从主机挂载到 backup 目录,之后执行 tar 命令生成一个 .tar 文件的备份
恢复
如果恢复一个数据到一个容器,首先创建带空数据卷的容器 dbdata2
|
|
然后创建另一个容器,挂载 dbdata2 容器卷中的数据卷,并使用 untar 解压备份文件到挂载容器卷中。
为了查看或者验证恢复的数据,可以再启动一个容器挂载同样的容器卷来查看