Docker详解(三)
序言:前两章我们主要介绍了Docker的概念和体系,以及Docker的镜像和容器命令,这一章我们将深入Docker镜像以及熟悉Docker的容器数据卷。OK,我们开始第三章的学习吧。
1. Docker镜像
1.1 镜像存储
要了解 Docker镜像的存储首先务必得了解联合文件系统 UnionFS(Union File System).
UnionFS(联合文件系统):Union文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,并且可以将不同目录挂载到同一个虚拟文件系统下。Union文件系统是Docker镜像的基础。镜像可以通过分层来进行继承,基于基础镜像,可以制作各种具体的应用镜像。

Docker镜像加载原理:
Docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFS。
bootfs(boot file system):主要包含bootloader和kernel, bootloader主要是引导加载kernel, Linux刚启动时会加载bootfs文件系统,在Docker镜像的最底层是bootfs。这一层与我们典型的Linux/Unix系统是一样的,包含boot加载器和内核。当boot加载完成之后整个内核就都在内存中了,此时内存的使用权已由bootfs转交给内核,此时系统也会卸载bootfs。
rootfs (root file system) :在bootfs之上。包含的就是典型 Linux 系统中的 /dev, /proc, /bin, /etc 等标准目录和文件。rootfs就是各种不同的操作系统发行版,比如Ubuntu,Centos等等。

1.2 base镜像
在了解base镜像之前,我们先说一下dockerFile,之前我们把镜像比作类、容器比作实例,如果有人不理解dockerFile的话,那么横向对比,你可以把它看作是 .class 文件。
那么base镜像就是 没有 FROM 或者 FROM scratch开头的 DockerFile所构建出来的镜像
base镜像通常都是各种 Linux发行版的镜像,如 Centos,Ubuntu,Debian 等
且base 镜像提供的是最小安装的Linux发行版,此外 Docker Hub上 99% 的镜像都是通过在base镜像中安装和配置需要的软件构建而来
下图是 官方 Centos 镜像 的 DockerFile内容

1.3 镜像Commit
docker commit 提交容器副本使之成为一个新的镜像
docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]
案例演示
1. 从Hub 上下载tomcat镜像到本地并成功运行 (也可采用阿里云加速下载)
docker pull tomcat

2. 故意删除上一步镜像生产tomcat的文档
注:如果不想新开窗口,可以 后台启动 tomcat ( docker run -d -p 8888:8080 tomcat )
docker exec -it 088c813ad8ca /bin/bash

3. 提交删除文档的 tomcat容器副本 作为一个新的镜像
docker commit -a="coke" -m="del tomcat docs" 088c813ad8ca coke/tomcat02:1.2

4. 运行我们上传成功的测试镜像
docker run -it -p 8888:8080 coke/tomcat02:1.2

2. Docker容器数据卷
2.1 基本介绍
Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,
那么当容器删除后,数据自然也就没有了。
为了保存数据,使容器之间可以进行数据共享,在Docker 中我们使用容器数据卷。
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
主要用途: 1. 容器的持久化 2. 容器间继承 + 共享数据
特点:
- 数据卷可在容器之间共享或重用数据
- 卷中的更改可以直接生效
- 数据卷中的更改不会包含在镜像的更新中
- 数据卷的生命周期一直持续到没有容器使用它为止

2.2 数据卷
我们接下来进行操作,尝试在容器 或者 DockerFile中 添加数据卷
直接命令添加
1、 命令添加
docker run -it -v /宿主机目录:/容器内目录 centos /bin/bash


2、查看容器卷是否挂载成功
docker inspect 容器ID

3、容器和宿主机之间数据共享
①. 尝试在Docker 容器内进行写入,主机查看是否实时更新


②. 尝试在主机进行文件修改,在Docker容器进行查看是否实时更新


注意:容器停止退出,主机修改文件,容器再次重启进入,主机修改的文件依然会同步到容器哦,有兴趣的可以试试。
DockerFile 添加 (此处我们只要学会使用Dockerfile添加容器卷就行,Dockerfile后面会介绍)
1、在主机根目录下 新建mydocker 文件夹,并进入
mkdir mydocker 新建一个mydocker文件夹
2、构建一个DockerFile
vim DockFile vim编辑器 编辑DockerFile文件
# volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,--------success1"
CMD /bin/bash
docker build -f /mydocker/Dockerfile -t coke/centos . 在centos基础上构建自己的Dockfile

3、run 容器
docker run -it coke/centos 运行我们刚刚构建的镜像的实例容器

4、获取主机的默认目录,后面 容器卷同步数据操作 同直接命令添加
docker inspect 容器ID

2.3 数据卷容器
命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器
- 我们以上一步新建的镜像 coke/centos 为模板运行容器 dc01/dc02/dc03
- 它们已经具有的容器卷:/dataVolumeContainer1、/dataVolumeContainer2
1、先启动一个父容器dc01,在dataVolumeContainer2新增内容

cd dataVolumeContainer2
touch doc01_add.txt
2、dc02/dc03继承自dc01,分别在dataVolumeContainer2中新增内容
docker run -it --name dc02 --volumes-from dc01 coke/centos dc02继承dc01

说明:doc02继承doc01后,容器卷中的文件做到了共享
docker run -it --name dc03 --volumes-from dc01 coke/centos dc03继承dc02

3、回到dc01可以看到02/03各自添加的数据都能共享了

4、删除dc01,dc02修改后打dc03可否访问


结论:容器之间的配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止。
Docker详解(三)的更多相关文章
- Docker详解(四) — Dockerfile剖析
目录 1.Dockfile简介 2. Dockerfile构建过程解析 3. Dockerfile体系结构 4. 案例 4.1 自定义mycentos 4.2 CMD/ENTRYPOINT 镜像案例 ...
- .NET DLL 保护措施详解(三)最终效果
针对.NET DLL 保护措施详解所述思路完成最终的实现,以下为程序包下载地址 下载 注意: 运行环境为.net4.0,需要安装VS2015 C++可发行组件包vc_redist.x86.exe.然后 ...
- Android 之窗口小部件详解(三) 部分转载
原文地址:http://blog.csdn.net/iefreer/article/details/4626274. (一) 应用程序窗口小部件App Widgets 应用程序窗口小部件(Widget ...
- WebSocket安卓客户端实现详解(三)–服务端主动通知
WebSocket安卓客户端实现详解(三)–服务端主动通知 本篇依旧是接着上一篇继续扩展,还没看过之前博客的小伙伴,这里附上前几篇地址 WebSocket安卓客户端实现详解(一)–连接建立与重连 We ...
- logback -- 配置详解 -- 三 -- <encoder>
附: logback.xml实例 logback -- 配置详解 -- 一 -- <configuration>及子节点 logback -- 配置详解 -- 二 -- <appen ...
- python设计模式之装饰器详解(三)
python的装饰器使用是python语言一个非常重要的部分,装饰器是程序设计模式中装饰模式的具体化,python提供了特殊的语法糖可以非常方便的实现装饰模式. 系列文章 python设计模式之单例模 ...
- Python操作redis字符串(String)详解 (三)
# -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1.SET 命令用于设置 ...
- Docker详解(二)
目录 1.Docker常用命令 1.1 镜像命令 1.2 容器命令 1.2.1 常用的容器命令 1.2.2 重要的容器命令 序言:上一章我们初步介绍了一下Docker的概念,那么这次我们着手于Dock ...
- pika详解(三)SelectConnection及其他Connection
pika详解(三)SelectConnection及其他Connection 本文链接:https://blog.csdn.net/comprel/article/details/94661147 ...
随机推荐
- Kubernetes 再深入一点点
kb master 运行如下容器 etcd 是 k8s 的核心, 主要负责k8s的核心数据处理及保存, 需要备份该数据,或者做集群 ,服务端口 2379(客户端服务) 2380(节点通信)kube-c ...
- 消息中间件——RabbitMQ(五)快速入门生产者与消费者,SpringBoot整合RabbitMQ!
前言 本章我们来一次快速入门RabbitMQ--生产者与消费者.需要构建一个生产端与消费端的模型.什么意思呢?我们的生产者发送一条消息,投递到RabbitMQ集群也就是Broker. 我们的消费端进行 ...
- Tomcat源码分析 (十)----- 彻底理解 Session机制
Tomcat Session 概述 首先 HTTP 是一个无状态的协议, 这意味着每次发起的HTTP请求, 都是一个全新的请求(与上个请求没有任何联系, 服务端不会保留上个请求的任何信息), 而 Se ...
- 微服务架构 - 网关 Spring Cloud Gateway
Spring Cloud Gateway 工作原理 客户端向 Spring Cloud Gateway 发出请求,如果请求与网关程序定义的路由匹配,则将其发送到网关 Web 处理程序,此处理程序运行特 ...
- aabccd统计每个字符出现的次数,结果显示{ a: 2, b: 1, c: 2, d: 1 };去掉重复的字符,使结果显示abcd
遍历字符串的方式和遍历数组的方式有点相似,或者说就是相同的.在学习数组的遍历方法之前,可以通过for循环去遍历数组,同样,字符串也可以:字符串跟数组都有一个length的属性.下面代码奉上,个人思路! ...
- .NET Core 小程序开发零基础系列(1)——开发者启用并牵手成功
最近几个月本人与团队一直与小程序打交道,对小程序的实战开发算比较熟悉,也因一些朋友经常问我各种小程序问题,无不能一一回答,想了很久,决定还是空余时间来写写文章吧,偶尔发现一个人安静的时候写文章特爽 ...
- Python: 转换文本编码
最近在做周报的时候,需要把csv文本中的数据提取出来制作表格后生产图表. 在获取csv文本内容的时候,基本上都是用with open(filename, encoding ='UTF-8') as f ...
- python 19 包
目录 1. 包 2. logging 日志 2.1 日志级别 2.2 配置日志格式: 2.3 logger 对象配置 1. 包 文件夹下具有__init__.py文件就是一个包 from bake.c ...
- DOM选择器之元素选择器
DOM中元素选择器 在DOM中我们可以将元素选择器分为两类:1.元素节点选择器:2.其它节点选择器.通过选择器选择HTML中的元素以对其进行操作,以此实现用JS对页面的操作. 一.元素节点选择器 1. ...
- HDU 6055
题意略. 思路:要你找出所有正多边形,其实是唬人的,整点的正多边形只有正方形,具体证明可以参考 2017国家队论文集-<正多边形>-杨景钦 详见代码: #include<bi ...