​ 我们平时判断一个电脑的性能主要看什么?磁盘读写?CPU的主频高低?还是内存的大小?可是作为个人使用者来说,这些参数高一些足够我们去使用了,可是对于一个大型系统甚至是超大型系统,当前的硬件是远远达不到的。而作为当前的云计算时代,虚拟化技术就发挥了自己的独特的作用。

​ 随着信息技术的快速发展,虚拟化技术也在不断的丰富和创新。从20世纪60年代的IBM推出大型主机虚拟机到现在的X86平台上的虚拟化,虚拟化既可以通过硬件模拟来实现,同时也可通过操作系统来实现,而当前的容器虚拟化就是充分地利用了操作系统的机制和特性,实现轻量级的虚拟化,在这些虚拟化技术中,Docker又是其中的佼佼者。

一、什么是Docker

1、Docker一个开源项目

​ Docker是一个基于Go语言实现的云开源项目,它诞生于2013年,最初发起者未dotCloud公司。目前Docker已经成为了一个生态体系,并已加入Linux基金会,遵循Apache2.0协议。目前主流的Linux操作系统都支持Docker,而Docker的主要目标是通过对应用组件的封装、分发、部署、运行等生命周期的管理,达到应用组件(Web应用 / 数据库服务 / 操作系统或编译器等)级别的“一次封装,到处运行”。

2、Linux容器技术

​ Docker引擎的基础就是Linux容器(Linux Containers,LXC)技术。对于容器技术,IBM DeveloperWorks给出了描述:容器有效地将由单个操作系统管理的资源划分到孤立的组中,以便更好地在孤立的组之间平衡有冲突的资源使用需求。与虚拟化相比,这即不需要指令级模拟,也不需要即时编译。容器可以在核心CPU本地运行指令,而不需要任何专门的解释机制。同时也避免了准虚拟化和系统调用替换中的复杂性。

​ 当然Linux容器也并不是一个全新的概念,只是后来LXC项目借鉴了前人成熟的容器设计理念,并基于一些新的内核特性实现了扩展性的虚拟化容器技术。关键的是,LXC由此被集成到了Linux内核中,而成为Linux系统轻量级容器技术的事实标准。

3、从Linux容器到Docker

​ 在Linux容器技术的基础上,Docker优化了容器的使用体验。同时,Docker提供了各种容器管理工具让用户无需关注底层的操作,可以简单地管理和使用。

二、为什么要使用Docker

1、Docker容器虚拟化的好处

​ 高效地构建应用,开发者能方便地创建运行在云平台上的应用,应用能够脱离底层机器,同时在任何时间和任何地点都是可获取的。而Docker提供容器打包应用,当我们在迁移系统时,只要启动需要的容器就可以了。这将节约时间,并降低部署过程出现问题的风险。

2、Docker在开发和运维中的优势

​ 对于开发和运维人员来说,最理想的就是一次性地创建和配置,可以在任意环境、任意时间让应用正常地运行。而Docker即可实现:1、更快速的交付和部署。2、更高效的资源利用。3、更轻松的迁移和扩展。4、更简单的更新管理。

3、Docker与虚拟机对比

​ 作为轻量级的虚拟化方式,Docker在运行应用上跟传统的虚拟机方式相比具有显著的优势:

​ 1、Docker容器更快,启动和停止都是秒级。

​ 2、Docker容器对系统资源需求更少。

​ 3、Docker指令简明,学习成本底。

​ 4、Docker通过Dockerfile配置文件支持灵活的自动化创建和部署机制,提高工作效率。

特性 容器 虚拟机
启动速度 秒级 分钟级
硬盘使用 一般未MB 一般为GB
性能 接近原生 弱于
系统支持量 单机支持上千个容器 一般几十个
隔离性 安全隔离 完全隔离

三、虚拟化与Docker比较

​ 虚拟化技术是一个通用的概念,在不同的领域有不同的理解。而在计算领域,一般指的是计算虚拟化或服务器虚拟化。虚拟化的核心是对资源进行抽象,目标为在同一机器上运行多个系统或应用,提高系统资源的利用率,同时降低成本、方便管理和容错容灾等好处。

​ 从类型区分,虚拟化技术可分为基于硬件的虚拟化和基于软件的虚拟化。而我们一般讨论的都是基于软件的虚拟化,而基于软件的虚拟化从对象层次上又分为应用虚拟化和平台虚拟化。其中主要讨论的又是平台虚拟化,平台虚拟化又可分为完全虚拟化、硬件辅助虚拟化、部分虚拟化、超虚拟化、操作系统级虚拟化。而Docker就属于操作系统级虚拟化。

​ 表1:传统的虚拟化方式

应用程序 应用程序
运行时环境 运行时环境
虚拟机操作系统 虚拟机操作系统
虚拟机管理程序
宿主机操作系统
硬件层

​ 表2:Docker的虚拟化方式

应用程序 应用程序
运行时环境 运行时环境
Docker容器支持
宿主机操作系统
硬件层

一、【Docker笔记】进入Docker世界的更多相关文章

  1. 二、【Docker笔记】Docker的核心概念及安装

    Docker主要有三大核心的概念,分别为镜像(Image).容器(Container)及仓库(Repository). 一.核心概念 1.Docker镜像 ​ Docker镜像其实与虚拟机镜像很类似, ...

  2. 三、【Docker笔记】Docker镜像

    镜像是Docker的三大核心概念之一.Docker在运行容器之前,本地需要存有镜像,若不存在则Docker会首先尝试从默认的镜像仓库中去下载,当然我们也可以去配置自己的仓库,如此就会从我们配置的仓库中 ...

  3. 四、【Docker笔记】Docker容器

    容器是Docker的另一个核心概念,容器就是镜像的一个运行实例,只是它具有一个可写的文件层,而镜像是一个只读的文件. 一.创建容器 1.新建容器 我们可以使用 docker create 命令来创建一 ...

  4. 六、【Docker笔记】Docker数据管理

    前几节我们介绍了Docker的基本使用和三大核心概念,那么我们在使用Docker的过程中,Docker中必然产生了大量的数据,对于这些数据我们需要查看或者对这些数据进行一个备份,也有可能容器之间的数据 ...

  5. 七、【Docker笔记】Docker中网络基础配置

    一个系统一般都包含多个服务组件,这些大量的服务组件不可能放在同一个容器中,这就需要多个容器之间可以互相通信.Docker提供了两种方式来实现网络服务:映射容器端口到宿主主机.容器互联机制. 一.端口映 ...

  6. Docker笔记一:Docker介绍

    目录 什么是Docker? Docker的核心概念 Docker镜像命令 Docker容器命令 Docker实战 查看我的镜像 启动Redis Docker中国镜像加速 血与泪的教训 什么是Docke ...

  7. Docker笔记(二):Docker管理的对象

    原文地址:http://blog.jboost.cn/2019/07/14/docker-2.html 在Docker笔记(一):什么是Docker中,我们提到了Docker管理的对象包含镜像.容器. ...

  8. Docker笔记(四):Docker镜像管理

    原文地址:http://blog.jboost.cn/2019/07/16/docker-4.html 在Docker中,应用是通过容器来运行的,而容器的运行是基于镜像的,类似面向对象设计中类与对象的 ...

  9. Docker笔记(七):常用服务安装——Nginx、MySql、Redis

    开发中经常需要安装一些常用的服务软件,如Nginx.MySql.Redis等,如果按照普通的安装方法,一般都相对比较繁琐 —— 要经过下载软件或源码包,编译安装,配置,启动等步骤,使用 Docker ...

随机推荐

  1. AI入门之KNN算法学习

    一.什么是KNN算法 kNN(k-NearestNeighbor),也就是k最近邻算法.顾名思义,所谓K最近邻,就是k个最近的邻居的意思.也就是在数据集中,认为每个样本可以用离他最距离近的k个邻居来代 ...

  2. Java程序员考研失败后的面试经历,oppo、VIVO、等面经

      温馨提示:有些可能会遗漏个别问题,都是最近一周的面试,有点忘了. 浪潮(一面挂) 你是网络工程的?对网络很了解? 解释一下什么是广播域 怎么划分子网 说一下CSS的几种分类器 数据库中有哪些聚集函 ...

  3. JavaScript常见的六种继承方式

    前言 面向对象编程很重要的一个方面,就是对象的继承.A 对象通过继承 B 对象,就能直接拥有 B 对象的所有属性和方法.这对于代码的复用是非常有用的. 大部分面向对象的编程语言,都是通过"类 ...

  4. 用ABAP 生成二维码 QR Code

    除了使用我的这篇blogStep by step to create QRCode in ABAP Webdynpro提到的使用ABAP webdynpro生成二维码之外,也可以通过使用二维码在线生成 ...

  5. 如何把.a转化为framework

    在Xcode中,framework比分散的.a和.h文件用起来方便的多.然而,只要你一找如何制作framework,多半你就会放弃,“怎么这么麻烦?!” 尤其是当已经有现成的.a和.h时,你就会更不能 ...

  6. elasticsearch 单机安装

    一.elasticsearch下载 1.elastic 官网:https://www.elastic.co/cn/ 2.elasticsearch 下载地址:https://www.elastic.c ...

  7. mysql的锁与事务

    1. MySQL中的事物 1.InnoDB事务原理 1. 事务(Transaction)是数据库区别于文件系统的重要特性之一,事务会把数据库从一种一致性状态转换为另一种一致性状态. 2. 在数据库提交 ...

  8. 打开ElasticSearch、kibana、logstash的正确方式

    作者:玩世不恭的Coder时间:2020-03-08说明:原创不易,本文为原创文章,未经允许不可转载,转载前请联系作者 打开ElasticSearch.kibana.logstash的正确方式 前言一 ...

  9. 操作系统-schedule函数

    1. Linux 0.11的调度函数schedule() 也就是找到了counter最大的进程,然后就跳出去执行switch_to,对应上面的优先级算法,而counter本身也是时间片,也作了轮转调度 ...

  10. Community Cloud零基础学习(四)Builder创建自定义的布局

    前几篇讲了Community Cloud权限配置等信息,但是没有太讲过 Community如何进行配置layout,本篇主要描述使用Builder去进行符合需求的Community Layout的构建 ...