文章目录

  • 1. Docker的基本组成
    • 1.1 Docker的架构图
    • 1.2 几个名词解释
  • 2. Run的执行原理
  • 3. Docker底层工作原理

Docker官网: https://www.docker.com/

Docker Hub官网:https://hub.docker.com/

1. Docker的基本组成

在讲解原理之前,我们先要了解一下Docker的基本组成以及一些常用到的名词解释,以便在后续的文章中能更好地理解。

1.1 Docker的架构图

从架构图中可以看出,一个完整的Docker有以下几个部分组成:

  1. Docker Client客户端
  2. Docker Dadmon守护进程
  3. Docker Image镜像
  4. Docker Container容器
  5. Docker Registry仓库

1.2 几个名词解释

镜像(image):

Docker 镜像(Image)就是一个只读的模板。镜像可以用来创建 Docker 容器,一个镜像可以创建多容器。 就好似 Java 中的 类和对象,镜像就相当于类,容器相当于对象!

容器(container)

Docker 利用容器(Container)独立运行的一个或一组应用。容器是用镜像创建的运行实例。
它可以被启动、开始、停止、删除。每个容器都是相互隔离的,保证安全的平台。
可以把容器看做是一个简易版的 Linux 环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。
容器的定义和镜像几乎一模一样,也是一堆层的统一视角,唯一区别在于容器的最上面那一层是可读可写的(可以执行一些命令)。

仓库(repository)

仓库(Repository)是集中存放镜像文件的场所。
仓库(Repository)和仓库注册服务器(Registry)是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签(tag)。
仓库分为公开仓库(Public)和私有仓库(Private)两种形式。
最大的公开仓库是 Docker Hub,存放了数量庞大的镜像供用户下载。
国内的公开仓库包括阿里云 、网易云等。

2. Run的执行原理

在上一篇文章中我们执行了docker run hello-world这样一个命令,这就等于是运行了hello-world镜像形成了一个容器

可以理解为:一个镜像在没运行的时候叫镜像,运行起来之后形成容器,容器里面运行的就是你刚才的镜像。

那么当我们执行了docker run hello-world之后它是如何运行起来的呢?我们把图接下来看。

我们发现当我们运行一个镜像,会先在本地找,如果本地没有,会到远程仓库中找,找到之后会下载下来运行。那如果运行了一个镜像仓库中也没有会如何呢?

通过图示内容我们可以抽象为这样一个流程:


这样一说是不是清晰多了。

3. Docker底层工作原理

Docker是怎么工作的?

Docker是一个Client-Server结构的系统,Docker守护进程运行在主机上, 然后通过Socket连接从客户端访问,守护进程从客户端接受命令并管理运行在主机上的容器。 容器,是一个运行时环境,就是我们在LOGO上看到的集装箱。

现在我们就应该理解了,容器是一个运行时的环境,他们之间是相互隔离的。我们可以在一个主机(守护进程)上同时运行多个容器,也就是运行多个环境,并由客户端通过Socket连接进行管理。

为什么Docker比较 VM 快?

  1. docker有着比虚拟机更少的抽象层。由于docker不需要Hypervisor实现硬件资源虚拟化,运行在docker容器上的程序直接使用的都是实际物理机的硬件资源。因此在CPU、内存利用率上docker将会在效率上有明显优势。

  2. docker利用的是宿主机的内核,而不需要Guest OS。因此,当新建一个容器时,docker不需要和虚拟机一样重新加载一个操作系统内核。而当新建一个虚拟机时,虚拟机软件需要加载Guest OS,这个新建过程是分钟级别的。而docker由于直接利用宿主机的操作系统,省略了这个过程,因此新建一个docker容器只需要几秒钟。


通过分析我们发现了最主要的两点:docker有着比虚拟机更少的抽象层。Docker和宿主机共享内核资源,减少了开销。

讲到这里,大家是不是对Docker的组成以及一些原理有所了解了?

Docker系列博客会持续更新,欢迎订阅。

【Docker篇】Docker的基本组成,底层原理分析相关推荐

  1. MyBatis 动态 SQL 底层原理分析

    MyBatis 动态 SQL 底层原理分析 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" p ...

  2. HashMap底层原理分析(put、get方法)

    1.HashMap底层原理分析(put.get方法) HashMap底层是通过数组加链表的结构来实现的.HashMap通过计算key的hashCode来计算hash值,只要hashCode一样,那ha ...

  3. Spring 事务原理篇:@EnableTransactionManagement注解底层原理分析技巧,就算你看不懂源码,也要学会这个技巧!

    前言 学习了关于Spring AOP原理以及事务的基础知识后,今天咱们来聊聊Spring在底层是如何操作事务的.如果阅读到此文章,并且对Spring AOP原理不太了解的话,建议先阅读下本人的这篇文章 ...

  4. java map原理_Java HashMap底层原理分析

    前两天面试的时候,被面试官问到HashMap底层原理,之前只会用,底层实现完全没看过,这两天补了补功课,写篇文章记录一下,好记性不如烂笔头啊,毕竟这年头脑子它记不住东西了哈哈哈.好了,言归正传,今天我 ...

  5. 【Docker】docker到底是个啥,底层原理

    一.总览 Docker说到底其实就是一个启动了多个Linux NameSpace的应用进程,而这个进程能够使用的资源量,则受Cgroups配置的限制. 其中NameSpace技术,通过对新创建的进程等 ...

  6. 十篇论文攻克自然语言处理底层原理!推荐大家复现!

    作为一个算法工程师,你要知道什么是自然语言处理中的核心问题? 我这里有一个答案:文本匹配,它是NLP任务中的一个基础且核心的模块.因为很多自然语言处理的任务都可以抽象成文本匹配问题. 例如信息检索可以 ...

  7. Feign底层原理分析-自动装载动态代理

    本篇文章仅介绍Feign的核心机制,包括如何交由Spring容器托管.动态代理机制等内容,不会过分深入细节. 1.什么是Feign? 这里套用Feign官方Github上的介绍:"Feign ...

  8. java虚拟机线程调优与底层原理分析_Java并发编程——多线程的底层原理

    " Java代码在编译后会变成Java字节码,字节码被类加载器加载到JVM里,JVM执行字节码,最终需要转化为汇编指令在CPU上执行,Java中所使用的并发机制依赖于JVM的实现和 CPU的 ...

  9. MyBatis动态SQL底层原理分析

    前言 废话不多说,直接进入文章. 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" parame ...

最新文章

  1. wamp解决ajax跨域问题
  2. 专家周 |360精确搜索VS今日头条精准推荐算法
  3. flink报错:Error: Static methods in interface require -target:jvm-1.8 已解决
  4. 小翔和泰拉瑞亚(线段树+思维)
  5. 阿里创业员工分享公司的BI选型之路!自研、开源的坑都踩过
  6. 四川大学锦城学院计算机考试题,四川大学锦城学院期考试试题(B卷)_15889.doc
  7. IBM TPM2.0 模拟器
  8. QT高级编程学习笔记(1)
  9. Axure RP 8文件按钮效果
  10. 广电为什么禁止投屏_手机投屏到电视机,以前可以投屏,现在不能了,是怎么回事,求解!...
  11. 计算机专业知识3,计算机专业知识试卷3
  12. 怎么发现愿景和目标 | 进击
  13. 7、万国觉醒建筑白天黑夜效果(Shader Graph)
  14. 寺庙公众号开发:vue实现祈福牌位的前端部分
  15. 界面原型设计工具开源软件
  16. 华为云搭建javaweb服务器
  17. Sign function
  18. MySQL自增列之起始与步长
  19. 二分法的算法及应用场景(只更新了一种)
  20. 均匀节点插值与切比雪夫插值以及龙格现象

热门文章

  1. Windows 10 与 kali 双系统安装
  2. python + selenium驱动 Chrome 浏览器,browsermobproxy记录har文件
  3. mysql查询cp值数据_写出创建产品销售数据库CPXS的所有表的SQL 语句。所包含的表如下:...
  4. iPhone 5 创建应用程序
  5. 国内外火控计算机发展水平,关于火控计算机提高可靠性的一些经验
  6. iOS16灵动岛横屏视频播放适配(ZFPlayer)
  7. 算法学习之- 动态规划
  8. 面向对象----自有属性和共有属性
  9. firstElementChild与firstChild区别
  10. 智能营销机器人具备哪些能力?