centos7下安装docker(13.2容器数据共享)
回想一下我们学了两种存储方式:storage driver和data volume,其中又分为bind mount和docker managed volume,我们知道storage driver就是镜像层和容器层的组合,在我们学习data volume时我们知道data volume其实就是host上面的文件或者是目录,给mount到容器中的,我们可以在host上直接更新容器的内容,这种方式实现了容器与host之间的共享存储
共享存储分为:容器与host之间
容器与容器之间
1。容器与host共享数据
我们学了两种类型的data volume,他们均能实现容器与host之间的共享数据,但方式有所区别:
bind muount:可以直接将要共享的目录mount到容器,例如:docker run -d -v /mnt/docker:/usr/lib/apache2/htdocs httpd
docker managed volume:就要麻烦些,由于volume位于host中的目录是容器在启动的时候才生成的,所以需要将共享的数据拷贝到volume中

在host下的/var/lib/docker/volumes/*****/_data下新建了一个文件,我们进入容器中,在相应的目录中可以看到新建的文件

当我们在容器中相应的挂载点增加一个文件时,我们在host上也是可以看到的,这就实现了数据共享!


可以利用docker cp这个命令在容器与host之间进行数据拷贝
2.容器之间共享数据
bind mount方法:就是将共享数据全部放在同一个bind mount中

新建三个容器,使其全部使用同一个bind mount

访问三个容器的httpd主页,内容一致

对host上的bind mount进行更新

三个容器中的内容也同时被更新了

当我们对其中一个容器进行更新的时候,其他容器的内容是否会被更新?host上的bind mount内容是否会被更新?




根据实验的效果来看,当我们更改其中一个容器的内容时,所有的容器的共享内容全部被改变,实现了容器之间的数据共享。
用volume container共享数据
volume container是专门为其他容器提供volume 的容器,它提供的卷可以是bind mount,也可以是docker managed volume

这里执行的是docker create:因为volume container是专门用来提供数据的,它本身不需要处于运行状态
这里通过-v的参数,mount了两个volume:
1.bind mount,存放web server的静态文件
2.docker managed volume存放一些实用工具
通过docker inspect可以查看到两个volume

其他容器可以通过--volumes-from来使用volume这个容器提供的volume

通过docker inspect查看容器volume

经过查看,3个容器使用的是相同的volume
进行测试:


三个容器已经共享了volume container中的volume
volume container的特点:
1.与bind mount相比不用为每个容器指定host path,所有容器在volume container中定义好了,容器只需要在volume container中进行关联
2.使用volume container的容器期mount point是一致的,有利于配置的规范和标准化,但也带来一定的局限,使用时综合考虑!
3.volume container的数据其实还是在host上面,只是通过volume container统一获取。
data-packed volume container实现数据共享
无论是通过bind mount还是volume container,数据都是host上,是否可以提供一个容器来存储共享的数据,并且在容器间实现共享呢?
可以通过data packed volume container的方式:原理就是将数据打包到镜像,然后通过docker managed volume共享。
首先通过dockerfile创建镜像:

ADD:将host下的htdocs添加到/usr/local/apache/htdocs
VOLUME:和-v具有相同的效果,用来创建docker managed volume,通过docker managed volume的方式,再将数据复制到docker managed volume自动创建的volume中


用新镜像创建data-packed volume container

启动容器并使用data-packed volume container


容器能够读取volume的数据
通过docker inspect查看容器的volume

我们可以看到:虽然说data-packed volume contaniner不依赖host,但是还是在host创建了一个/var/lib/docker/volume/*******/_data/index.html
而且当我们删除这个目录的时候,http是无法访问的
这一块还是需要继续研究:容器到底如何脱离host,实现容器间的数据共享?
---恢复内容结束---
centos7下安装docker(13.2容器数据共享)的更多相关文章
- centos7下安装docker(19容器架构)
What,Why,How What:什么是容器? 说起容器大家想到的是什么? 集装箱(container),虚拟机,docker,k8s 1. 没毛病,因为容器与集装箱的英文都可以翻译成co ...
- centos7下安装docker(11容器操作总结)
这段时间主要是学习了对容器的操作,包括:容器的状态:start,stop,restart,rename,pause,unpause,rm,attach,exec,kill,logs:还学习了对容器的资 ...
- centos7下安装docker(10容器底层--cgroup和namespace)
cgroup和namespace是实现容器底层的重要技术 cgroup:实现资源限制 namespace:实现资源隔离 1.cgroup:control group Linux操作系统通过cgroup ...
- centos7下安装docker(9容器对资源的使用限制-内存)
一个docker Host上面会运行若干容器,每个容器都需要CPU,内存和IO资源.容器提供了控制分配多少CPU,内存给每个容器的机制,避免摸个容器因占用太多资源而影响其他 ...
- CentOS7下安装docker(Docker系列1)
CentOS7下安装docker 系统要求 为了安装docker,需要准备 64-bit的CentOS 7 删除非官方的Docker包 yum的仓库中有一个很旧的Docker包, 现在Docker官方 ...
- docker(一) Centos7下安装docker
docker(一) Centos7下安装dockerdocker(二) windows10下安装dockerdocker(三) 镜像和容器常用命令 docker(四) 使用Dockerfile构建镜像 ...
- centos7下安装docker与镜像加速
1.背景 centos7下安装docker 2.安装 第一步:检查是否为centos7版本 第二步:依赖环境安装 执行如下两个命令: yum -y install gcc yum -y install ...
- centos7 下安装docker报错:You could try using...
搞了台VPS,想要装docker,发现死活装不上,各种报错.之前系统是centos6,发现官方现在已经不支持centos6了,遂升级到centos7,然后还是出现下面这个错误. Error: Pack ...
- centos7下安装docker(13.4容器volume总结)
最近我们学习了docker 存储,首先docker存储有两种:storage driver和data volume. storage driver是由镜像层和容器层组成的,可以通过docker ins ...
随机推荐
- SpringBoot JPA + H2增删改查示例
下面的例子是基于SpringBoot JPA以及H2数据库来实现的,下面就开始搭建项目吧. 首先看下项目的整体结构: 具体操作步骤: 打开IDEA,创建一个新的Spring Initializr项目, ...
- [HAOI 2016]找相同字符
Description 题库链接 给定两个只含小写字母字符串 \(s_1,s_2\) ,求出在两个字符串中各取出一个子串使得这两个子串相同的方案数.两个方案不同当且仅当这两个子串中有一个位置不同. \ ...
- [转]nodejs之cordova 跨平台开发
本文转自:https://blog.csdn.net/bubuxindong/article/details/53787392 cordova原名phonegap,虽然adobe收购了phonegap ...
- 为 Html 5 和 CSS 3.0 而生——Modernizr的介绍和使用
传统浏览器目前不会被完全取代,令你难以将最新的 CSS3 或 HTML5 功能嵌入你的网站. Modernizr 正是为解决这一难题应运而生,作为一个开源的 JavaScript 库,Moderniz ...
- 互联网推送服务原理:长连接+心跳机制(MQTT协议)
互联网推送消息的方式很常见,特别是移动互联网上,手机每天都能收到好多推送消息,经过研究发现,这些推送服务的原理都是维护一个长连接(要不不可能达到实时效果),但普通的socket连接对服务器的消耗太大了 ...
- c# 数组协变
class a{} class b:a{} a[] arr=new a[3]; a[] arr2=new a[3]; 给arr 数组赋值 arr[0]=new a(); arr2[0]=new b() ...
- C#基础 数据类型 类型转换
本节主要讲解数据类型和各类型之间的转换,两点都是重点,难点在于各种转换的活学活用. 一 数据类型 (一)基本数据类型 1 值类型 (1)整形 int ...
- Java并发编程:JMM (Java内存模型) 以及与volatile关键字详解
目录 计算机系统的一致性 Java内存模型 内存模型的3个重要特征 原子性 可见性 有序性 指令重排序 volatile关键字 保证可见性和防止指令重排 不能保证原子性 计算机系统的一致性 在现代计算 ...
- Ajax提交用FormData()上传文件
1.form声明如下 2.ajax设置如下 var formData = new FormData(document.getElementById("form")); $.ajax ...
- 2017-10-29 用中文命名API的意义和途径
"中文编程"知乎专栏原链 在前文对在代码中使用中文命名的质疑与回应中阐述了在代码中使用中文命名的益处. 此文将从软件使用者的角度阐述对API中文化的意义并探讨实现途径. 当然, 文 ...