DevOps
docker
docker
  • 基础知识
    • 概述
      • 核心概念
      • Docker 引擎
      • 基本架构
      • 联合文件系统
      • 网络虚拟化
    • 安装
      • 安装Docker Engine
      • 以非 root 用户使用 Docker
      • 配置 Docker 服务
    • 3. Docker镜像
      • 3.1 获取镜像(pull)
      • 3.2 查看镜像信息
        • images
        • tag
        • inspect
        • history
      • 3.3 搜寻镜像(search)
      • 3.4 删除镜像(rmi)
      • 3.5 清理镜像(prune)
      • 3.6 创建镜像
        • 基于已有容器创建
        • 基于本地模板导入
        • 基于Dockerfile创建
      • 3.7 导出镜像(save)
      • 3.8 导入镜像(load)
      • 3.9 上传镜像(push)
    • 4. Docker容器
      • 4.1 新建容器(create)
      • 4.2 启动容器(start)
      • 4.3 新建并启动容器(run)
      • 4.4 查看容器输出(logs)
      • 4.5 暂停容器(pause)
      • 4.6 恢复容器(unpause)
      • 4.7 停止止容器(stop)
      • 4.8 清除容器(prune)
      • 4.9 重启容器(restart)
      • 4.10 进入容器
      • 4.11 删除容器(rm)
      • 4.12 导出容器(export)
      • 4.13 导入容器(import)
      • 4.14 查看容器详情(inspect)
      • 4.15 查看容器内进程(top)
      • 4.16 查看统计信息(stats)
      • 4.17 复制文件(cp)
      • 4.18 查看变更(diff)
      • 4.19 更新配置(update)
    • 5. Docker仓库
      • 5.1 Docker Hub
      • 5.2 本地私有仓库
        • 使用HTTPS协议
        • 添加用户认证
        • 使用push时遇到的一些坑
    • 6. Docker数据管理
      • 6.1 数据卷
      • 6.2 数据卷容器
      • 6.3 利用数据卷容器来迁移数据
    • 7. 端口映射与容器互联
      • 7.1 端口映射
      • 7.2 容器互联
    • 8. Dockerfile
      • 8.1 基本结构
      • 8.2 指令说明
        • ARG
        • FROM
        • LABEL
        • EXPOSE
        • ENV
        • ENTRYPOINT
        • VOLUME
        • USER
        • WORKDIR
        • ONBUILD
        • STOPSIGNAL
        • HEALTHCHECK
        • SHELL
        • RUN
        • CMD
        • ADD
        • COPY
      • 8.3 创建镜像
      • 8.4 最佳实践
    • 9. Compose
      • 9.1 安装
      • 9.2 Compose文件
        • 9.2.1 services
        • 9.2.2 networks
        • 9.2.3 多文件Compose
          • Extend
          • Merge
          • Include
        • 9.2.4 锚点和别名
      • 9.3 Compose命令
      • 9.4 实例
  • 中间件安装
    • 安装tomcat
    • 安装redis
      • 单机
      • Cluster集群
    • 安装mysql
    • 安装ssh服务
      • 基于commit命令创建
      • 使用Dockerfile创建
    • 安装Apache
    • 安装ngnix
  • 操作系统镜像
    • BusyBox
    • ☑️Alpine
    • Debian/Ubuntu
    • CentOS/Fedora
  • Tips
    • docker 引擎开启远程访问
    • dockerfile-maven-plugin
    • IDEA 连接远程 docker
Powered by GitBook
On this page
  • 1. 创建数据卷
  • 2. 绑定数据卷

Was this helpful?

Edit on GitHub
  1. 基础知识
  2. 6. Docker数据管理

6.1 数据卷

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

数据卷可以提供很多有用的特性:

  • 数据卷可以在容器之间共享和重用,容器间传递数据将变得高效与方便;

  • 对数据卷内数据的修改会立马生效,无论是容器内操作还是本地操作;

  • 对数据卷的更新不会影响镜像,解耦开应用和数据;

  • 卷会一直存在,直到没有容器使用,可以安全地卸载它。

1. 创建数据卷

Docker提供了docker volume命令来管理数据卷,如下命令可以快速在本地创建一个数据卷:

$ docker volume create test
test

$ sudo ls -l /var/lib/docker/volumes
drwx-----x. 3 root root     19 10月 19 09:46 test

新建的数据卷位于/var/lib/docker/volumes路径下。

除了create子命令外,docker volume还支持inspect(查看详细信息)、ls(列出已有数据卷)、prune(清理无用数据卷)、rm(删除数据卷)等。

2. 绑定数据卷

除了使用dockers volume命令来管理数据卷外,还可以在创建容器时将主机本地的任意路径挂载到容器内作为数据卷,这种形式创建的数据卷称为绑定数据卷。

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

  • volume:普通数据卷,映射到主机/var/lib/docker/volumes路径下;

    $ docker run -itd --name volume-test \
        --mount type=volume,source=test,destination=/opt/test ubuntu:18.04
  • bind:绑定数据卷,映射到主机指定路径下;

    $ mkdir -p /tmp/data  
    $ docker run -itd --name bind-test \
        --mount type=bind,source=/tmp/data,destination=/opt/test ubuntu:18.04

    上述命令等同于使用旧的 -v 标记可以在容器内创建一个数据卷:

    $ docker run -itd --name v-test \
        -v /tmp/data:/opt/test ubuntu:18.04

    其中,本地目录的路径必须是绝对路径,容器内路径可以为相对路径。如果目录不存在,Docker会自动创建。

    Docker挂载数据卷的默认权限是读写(rw),用户也可以通过ro指定为只读,加了ro之后,容器内对所挂载数据卷内的数据就无法修改了。

    $ docker run -itd --name v-test2 \
        -v /tmp/data:/opt/test:ro ubuntu:18.04

    --mount绑定的本地路径如果不存在会报错,并不会自动创建。

  • tmpfs:临时数据卷,tmpfs类型的数据卷,其中数据只存在于内存中,容器退出后自动删除。

    $ docker run -itd --name tmpfs-test \
        --mount type=tmpfs,destination=/opt/test ubuntu:18.04
Previous6. Docker数据管理Next6.2 数据卷容器

Last updated 1 year ago

Was this helpful?