Docker数据卷将数据存储到主机而非容器,多个容器需要共享数据时,常常使用数据卷。

  1. 为容器设置数据卷(不指定主机目录)

  2. 容器与主机之间、容器与容器之间共享数据卷(指定主机目录)

  3. 使用Docker数据卷容器

  

  • 为容器设置数据卷(不指定主机目录)

  为容器设置数据卷只需要在创建容器时使用 -v 参数指定目录即可。下面示例一个以/data目录设置为数据卷,并存储文件在data数据卷内,并回到主机查看数据卷中的内容。首先创建容器,执行命令创建容器:

sudo docker run -i -t --name example-volume -v /data ubuntu /bin/bash

  命令执行成功后会创建容器并进入容器终端bash,切换目录到/data目录,创建test.txt文件,写入内容“Just a test.”,命令执行依次如下:

cd data
echo "Just a test." >> test.txt

  容器内执行exit命令后推出到主机,使用docker inspect 查看刚才创建的镜像的Source的值。Source的值就是容器的数据卷在主机中的存储位置。

sudo docker inspect example-volume | grep Source

  命令结果使用管道查找包含Source关键字的信息,可以看到存储的目录/var/lib/docker/volumes/1381f734a4c3207929784b149137d72cfd71987750c2e74593e81823bcfac2c5/_data。

  目录下面有刚才在容器内创建的test.txt文件。使用cat命令查看一下内容:

sudo cat /var/lib/docker/volumes/1381f734a4c3207929784b149137d72cfd71987750c2e74593e81823bcfac2c5/_data/test.txt

  所以,在容器内设置的数据卷其实对应于docker管理的一个主机存储目录。

  •  容器与主机之间、容器与容器之间共享数据卷(指定主机目录)

  容器与主机共享数据卷只需要在创建容器时指定主机目录与容器目录之间的共享就可以了,格式是使用 -v 参数,“-v 主机目录:容器目录“ 选项指定具体的共享目录。下面示例一个主机~/Document目录与容器/Document目录的数据卷共享。执行命令创建容器:

sudo docker run -i -t --name hello-volume1 -v ~/Document:/Document ubuntu /bin/bash

  命令执行成功后会进入容器终端,输入内容“Just a test.”到文件/Document/test.txt文件并退出回到主机终端

  在主机的~/Document目录下可以看到test.txt文件,使用cat命令查看其内容。

cat ~/Document/test.txt

  下面创建第二个容器,共享主机的~/Document目录,执行命令:

sudo docker run -i -t --name hello-volume2 -v ~/Document:/Document ubuntu /bin/bash

  命令执行成功后会进入容器终端,使用cat命令查看共享数据卷下的test.txt文件,执行命令:

cat /Document/test.txt

  从执行结果来看,前面第一个容器hello-volume1创建的文件test.txt也出现在容器hello-volume2中。其实若在两个容器中任何一个容器中的共享目录/Document或者主机的~/Document目录下创建文件,它们三者都可以使用,这就是数据卷的功能,可以实现多个容器共享数据。

  • 使用Docker数据卷容器

  数据卷容器是设置数据卷的容器,专门提供数据卷供其它容器共享。从普通容器连接到数据卷容器后,即可访问数据卷容器内的数据卷目录。下面创建一个名为data-volume的数据卷容器,执行命令:

sudo docker run -i -t --name data-volume -v ~/Document:/Document ubuntu /bin/bash

  然后输入测试内容到容器的/Document目录下,输入命令:

echo "data-volume" >> /Document/data

  文件写入后,这时候需要把数据卷容器后台运行,依次按Ctrl+P、Ctrl+Q,在不停止容器的前提下推出Bash Shell。

  这时,创建普通容器,连接到刚刚创建的data-volume数据卷容器,运行Bash Shell,输出/Document目录下的data文件内容,执行命令:

sudo docker run -i -t --name hello --volumes-from data-volume ubuntu /bin/bash

  命令执行成功后会进入容器,执行cat命令查看数据卷容器的内容:

cat /Document/data

  用于连接数据卷容器的选项格式为 --volumes-from <数据卷容器> ,注意确保连接的数据卷容器是启动运行状态。另外,数据卷容器也可以被多个普通容器连接上去。

Docker学习笔记之使用Docker数据卷的更多相关文章

  1. Docker学习笔记之了解 Docker 的核心组成

    0x00 概述 在掌握 Docker 的一些背景知识后,我们还不得不花费一节的篇幅来简单介绍有关 Docker 核心的一些知识.当然,大家不要觉得有“核心”这类的词,我们就要在这一节中深入 Docke ...

  2. docker学习笔记-04:docker容器数据卷

    一.容器数据卷是什么 1.为了保存docker容器运行时产生的数据,做数据的持久化,我们需要用到容器数据卷.因为如果不通过docker commit 生成新的镜像,那么当容器被删除时,数据自然就没有了 ...

  3. Docker学习笔记之使用 Docker Compose 管理容器

    0x00 概述 通过之前的介绍,我们已经基本掌握了构建.运行容器的方法,但这还远远不够,由于 Docker 采用轻量级容器的设计,每个容器一般只运行一个软件,而目前绝大多数应用系统都绝不是一个软件所能 ...

  4. Docker学习笔记之搭建Docker运行环境

    0x00 概述 既然 Docker 是一款实用软件,我们就不得不先从它的安装说起,只有让 Docker 运行在我们的计算机上,才能更方便我们对 Docker 相关知识和使用方式的学习.得益于与商业性的 ...

  5. Docker学习笔记六:Docker搭建企业级私有仓库

    前言 Docker不仅是一个强大的服务器部署工具,而且它还有一个官方的Docker Hub registry用于储存Docker镜像.上传镜像到Docker Hub是免费的,上传的镜像文件同时也对公共 ...

  6. Docker学习笔记之搭建Docker私有仓库

    Docker仓库服务器名为Docker注册(registry)服务器.可以使用docker push命令将镜像上传到注册服务器,也可以使用docker pull命令下载服务器的镜像. Docker注册 ...

  7. docker 学习笔记21:docker连接网络的设置

    1.如果docker主机不需要通过代理连接外网 则docker的相关命令(如docker search)或docker容器与网络相关的操作都可以正常进行,不需要特殊设置. 2.当docker主机 是通 ...

  8. docker 学习笔记20:docker守护进程的配置与启动

    安装好docker后,需要启动docker守护进程.有多种启动方式. 一.服务的方式 因为docker守护进程被安装成服务.所以,可以通过服务的方式启停docker守护进程,包括查看状态. sudo ...

  9. Docker学习笔记二:Docker常用命令及提升拉取镜像的速度

    一.Docker命令: 1.docker images   //命令用来查看docker中所包含的镜像信息 2.docker ps -a    //命令用来查看docker中所包含所有容器信息(运行状 ...

随机推荐

  1. 访问控制列表ACL应用

    ACL的应用的场景 应用在三层接口 • Nat地址转换 Nat(network address translation,地址转换)是将数据报报头中的ip地址转换为另一个ip地址的过程,主要用于实现内部 ...

  2. C#跳过工作日,计算几个工作日之后到期的方法

    需求:消费者投诉企业,企业在2个工作日之内做出应答. 分析:1.工作日要刨去周末和法定节假日,而且每年的节假日不一样. 2.消费者可以在任意时间发起投诉,如果在非工作日发起了投诉,那么计算时间应该从工 ...

  3. Oracle数据导入Mysql中

    一.Navicat Premium中的数据迁移工具 为了生产库释放部分资源,需要将API模块迁移到mysql中,及需要导数据. 尝试了oracle to mysql工具,迁移时报错不说,这么大的数据量 ...

  4. Flink 自定义触发器

    import org.apache.flink.api.common.state.ReducingState; import org.apache.flink.api.common.state.Red ...

  5. Spark-6-如何缓解消除数据倾斜

    1 尽量避免数据源的数据倾斜 比如数据源是Kafka 以Spark Stream通过DirectStream方式读取Kafka数据为例.由于Kafka的每一个Partition对应Spark的一个Ta ...

  6. babel 与 ast

    什么是 babel Babel 是一个工具链,主要用于将 ECMAScript 2015+ 版本的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中. 什 ...

  7. SQL注入----盲注总结

    参考文章:https://mp.weixin.qq.com/s?__biz=MzIzMTc1MjExOQ==&mid=2247490388&idx=1&sn=c677837d7 ...

  8. 用burp爆破tomcat的过程

    首先burp抓包,将抓到的包放到intruder中 通过burp中自带的解码得知账号密码中有个":"号 所以我们选择的数据类型为Custom iterator 第二条输入" ...

  9. 工作3年,看啥资料能月薪30K?

    作者:小傅哥 博客:https://bugstack.cn Github:https://github.com/fuzhengwei/CodeGuide/wiki 沉淀.分享.成长,让自己和他人都能有 ...

  10. linux目录和Windows目录对比

    linux目录和Windows目录对比 我们应该知道 Windows 有一个默认的安装目录专门用来安装软件.Linux 的软件安装目录也应该是有讲究的,遵循这一点,对后期的管理和维护也是有帮助的. / ...