美文网首页
Docker 数据管理

Docker 数据管理

作者: wean_a23e | 来源:发表于2019-01-22 23:54 被阅读16次

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

    • 数据卷(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 数据管理

          本文链接:https://www.haomeiwen.com/subject/cahdjqtx.html