Docker 数据管理

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

  • 数据卷(Data Volumes):容器内数据直接映射到本地主机环境
  • 数据卷容器(Data Volume Containers):使用特定容器维护数据卷

本文将首先介绍如何在容器内创建数据卷,并且把本地目录或文件挂载到容器内的数据卷中。接下来,介绍如何使用数据卷容器在容器和主机、容器和容器之间共享数据,并实现数据的备份和恢复。

1. 数据卷

数据卷(Data Volumes)是一个可供容器使用的特殊目录,它将主机操作系统目录直接映射进容器,类似于 Linux 中的 mount 行为。

数据卷的特性有:

  • 数据卷可以在容器之间共享和重用,容器间传递数据将变得高效和方便
  • 对数据卷内的数据的修改会立马生效,无论容器内操作还是本地操作
  • 对数据卷的更新不会影响镜像,解耦开应用和数据
  • 卷会一直存在,直到没有容器使用,可以安全地卸载它

1.1 创建普通数据卷

例子为 docker volume create -d local test 会在 /var/lib/docker/volumes 路径下创建新的数据卷 test。

docker volume 的其他子命令还有 inspect (查看详细信息)、ls (列出已有数据卷)、prune (清理无用数据卷) 、rm (删除数据卷) 等,读者可以自行实践。

1.2 绑定数据卷

在创建容器时将主机本地的任意路径挂载到容器内作为数据卷,这种形式创建的数据卷称为绑定数据卷。

在用 docker [container] run 命令的时候,可以使用 -mount 选项来使用数据卷。
-mount 选项支持三种类型的数据卷,包括:

  • volume : 普通数据卷,映射到主机 /var/lib/docker/volumes 路径下
  • bind : 绑定数据卷,映射到主机指定路径下
  • tmpfs : 临时数据卷,只存在于内存中

下面演示使用 training/webapp 镜像创建一个 web 容器,并创建一个数据卷挂载到容器的 /opt/webapp 目录:
docker run -d -P --name=web --mount type=bind,source=/webapp,destination=/opt/webapp training/webapp python app.py
上述命令的旧形式是:
docker run -d -P --name=web -v /webapp:/opt/webapp training/webapp python app.py

如果要设置容器对数据卷的权限是只读,可以通过 ro 指定为只读:
docker run -d -P --name=web -v /webapp:/opt/webapp:ro training/webapp python app.py

如果直接挂载一个文件到容器内,那么修改文件会导致报错误信息。应该挂载整个目录到容器内。

2. 数据卷容器

如果要在多个数据卷之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。共享的方式是在 docker [container] run 命令中使用 --volumes-from 参数指定挂载的数据卷。例如:

docker run -it -v /dbdata --name=dbdata ubuntu

root@38169762fbe4:/# docker run -it --volumes-from dbdata --name=db1 ubuntu
bash: docker: command not found
root@38169762fbe4:/# ls
bin  boot  dbdata  dev  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
root@38169762fbe4:/# cd dbdata/
root@38169762fbe4:/dbdata# ls
root@38169762fbe4:/dbdata# touch db1
root@38169762fbe4:/dbdata# ls
db1
root@38169762fbe4:/dbdata#
PS C:\Users\刘跃群> docker run -it --volumes-from dbdata --name bd2 ubuntu
root@14f22d2668b6:/# ls
bin  boot  dbdata  dev  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
root@14f22d2668b6:/# cd dbdata/
root@14f22d2668b6:/dbdata# ls
db1

在这个例子中,创建了数据卷 dbdata 容器挂载了绑定数据卷 /webapp,其他两个容器 db1, db2 共享了这个数据卷,并在 db1 容器中创建了 db1 文件,在 db2 容器中看到了这个文件。

3. 利用数据卷容器来迁移数据

3.1 备份

例子:docker run --volumes-from dbdata -v $(pwd):/backup --name=worker ubuntu tar cvf /backup/backup.tar /dbdata

在这里例子中,

  1. 利用了 ubuntu 创建了一个容器 worker。
  2. 使用 --volumes-from dbdata 参数来让 worker 容器挂载 dbdata 容器的数据卷(即 dbdata) 数据卷。
  3. 使用 -v $(pwd):/backup 参数来挂载当前目录到 worker 容器的 /backup 目录。
  4. worker 容器启动后,使用 tar cvf /backup/backup.tar /dbdata 命令将 /dbdata 下内容备份为容器内的 /backup/backup.tar,即宿主机下当前目录下的 backup.tar。

3.2 恢复

恢复的思路与备份相反,还是创建一个执行恢复操作的容器,同时挂载要恢复数据的数据卷和有数据的数据卷,然后把备份内容恢复到要恢复数据的数据卷即可。

你可能感兴趣的:(Docker 数据管理)