Docker学习笔记之使用Docker数据卷
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数据卷的更多相关文章
- Docker学习笔记之了解 Docker 的核心组成
0x00 概述 在掌握 Docker 的一些背景知识后,我们还不得不花费一节的篇幅来简单介绍有关 Docker 核心的一些知识.当然,大家不要觉得有“核心”这类的词,我们就要在这一节中深入 Docke ...
- docker学习笔记-04:docker容器数据卷
一.容器数据卷是什么 1.为了保存docker容器运行时产生的数据,做数据的持久化,我们需要用到容器数据卷.因为如果不通过docker commit 生成新的镜像,那么当容器被删除时,数据自然就没有了 ...
- Docker学习笔记之使用 Docker Compose 管理容器
0x00 概述 通过之前的介绍,我们已经基本掌握了构建.运行容器的方法,但这还远远不够,由于 Docker 采用轻量级容器的设计,每个容器一般只运行一个软件,而目前绝大多数应用系统都绝不是一个软件所能 ...
- Docker学习笔记之搭建Docker运行环境
0x00 概述 既然 Docker 是一款实用软件,我们就不得不先从它的安装说起,只有让 Docker 运行在我们的计算机上,才能更方便我们对 Docker 相关知识和使用方式的学习.得益于与商业性的 ...
- Docker学习笔记六:Docker搭建企业级私有仓库
前言 Docker不仅是一个强大的服务器部署工具,而且它还有一个官方的Docker Hub registry用于储存Docker镜像.上传镜像到Docker Hub是免费的,上传的镜像文件同时也对公共 ...
- Docker学习笔记之搭建Docker私有仓库
Docker仓库服务器名为Docker注册(registry)服务器.可以使用docker push命令将镜像上传到注册服务器,也可以使用docker pull命令下载服务器的镜像. Docker注册 ...
- docker 学习笔记21:docker连接网络的设置
1.如果docker主机不需要通过代理连接外网 则docker的相关命令(如docker search)或docker容器与网络相关的操作都可以正常进行,不需要特殊设置. 2.当docker主机 是通 ...
- docker 学习笔记20:docker守护进程的配置与启动
安装好docker后,需要启动docker守护进程.有多种启动方式. 一.服务的方式 因为docker守护进程被安装成服务.所以,可以通过服务的方式启停docker守护进程,包括查看状态. sudo ...
- Docker学习笔记二:Docker常用命令及提升拉取镜像的速度
一.Docker命令: 1.docker images //命令用来查看docker中所包含的镜像信息 2.docker ps -a //命令用来查看docker中所包含所有容器信息(运行状 ...
随机推荐
- logstash导入DNS解析数据到es中,中间有filebeat
这个过程中,主要用logstash处理数据的时候不好处理. 在logstash-sample.conf这个配置文件中的配置,我用这个监控filebeat的5044端口 # Sample Logstas ...
- sqli-labs less32-37(宽字节注入)
less-32 Bypass addslashes() less-33 Bypass addslashes() less-34 Bypass Add SLASHES less-35 addslashe ...
- Python最会变魔术的魔术方法,我觉得是它!
在上篇文章中,我有一个核心的发现:Python 内置类型的特殊方法(含魔术方法与其它方法)由 C 语言独立实现,在 Python 层面不存在调用关系. 但是,文中也提到了一个例外:一个非常神秘的魔术方 ...
- Python命令行模块(sys.argv,argparse,click)
Python作为一门脚本语言,经常作为脚本接受命令行传入参数,Python接受命令行参数大概有三种方式.因为在日常工作场景会经常使用到,这里对这几种方式进行总结. 命令行参数模块 这里命令行参数模块平 ...
- selenium 浏览器的操作
一.浏览器的最大化 #coding=utf-8 from selneium import wbedriver driver = wbedriver.Firefox() #将webdriver 的Fir ...
- js下 Day09、事件(二)
一.事件流 事件流描述的是从页面中接收事件的顺序,目前主要有三个模型: #1. 事件冒泡: 事件开始时由最具体的元素接收,然后逐级向上传播到较为不具体的元素
- phpstorm ext-json is missing in composer.json
- 详解Python Google Protocol Buffer
为什么要使用PB? PB(Protocol Buffer)是 Google 开发的用于结构化数据交换格式,作为腾讯云日志服务标准写入格式.因此用于写入日志数据前,需要将日志原始数据序列化为 PB 数据 ...
- python 做回归
1 一元线性回归 线性回归是一种简单的模型,但受到广泛应用,比如预测商品价格,成本评估等,都可以用一元线性模型.y = f(x) 叫做一元函数,回归意思就是根据已知数据复原某些值,线性回归(regre ...
- Hyperledger fabric 链码篇GO(四)
Hyperledger fabric 链码篇GO(四) fabric中的链码也就是我们区块链所认知的智能合约,fabric中可由nodejs,java,go编写,本篇只针对GO语言编写链码.将详细介绍 ...