参考源

https://www.bilibili.com/video/BV1og4y1q7M4?spm_id_from=333.999.0.0

https://www.bilibili.com/video/BV1kv411q7Qc?spm_id_from=333.999.0.0

版本

本文章基于 Docker 20.10.11


工作中的困扰

在研发工作中,想必都有这样的场景:

测试:生产环境发版后又出问题了。

运维:我是按照开发给的包部署的。

开发:我本地没问题呀。

一款产品,开发生产两套环境,运维人员环境配置费时费力,且很容易出现问题。

出现问题后,开发人员和运维人员排查问题都是十分痛苦的,因为一个产品往往涉及到诸多环境,可能产生影响的因素实在太多。

寻求解决

要是能够把代码环境一块提供,运维人员拿来就直接运行,这个问题就迎刃而解了。

这就是所谓开发即运维,既能保证系统稳定性,也能提高部署效率。

为解决这一问题,Docker 横空出世。

历史

2010 年,几个搞 IT 的人,在美国成立一家公司 dotCloud

一开始他们是做一些 PaaS 的云计算服务。

他们将自己的容器化技术命名为 Docker

Docker 基于 Go 语言开发。

Docker 刚诞生的时候,并没有引起行业的注意,这也导致 dotCloud 快要经营不下去。

为了公司能生存,他们决定开源,以寻求更多的关注。

2013 年,Docker 开源,一下子爆火。

刚开源的时候,每个月都会更新一个版本。

2014 年 4 月 9 日,Docker 1.0 发布。

简介

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

文档:https://docs.docker.com/docker-for-windows/

命令:https://docs.docker.com/engine/reference/run/

仓库:https://hub.docker.com/

Docker 是一个开源的应用容器引擎。

Docker 的思想来自于集装箱,彼此之间隔离。

Docker 通过隔离机制,可以将服务器利用到极致。

Docker 容器完全使用沙箱机制,相互之间不会有任何接口。

结构

  • 镜像(image):Docker 镜像好比一个模板,可以用来创建容器(container),一个镜像可以创建多个容器。
  • 容器(container):容器可以理解为一个微型的系统。
  • 仓库(repository):存放镜像的地方。

底层原理

Docker 是一个 Client-Server 结构的系统。

Docker 的守护进程运行在主机上,通过 Socket 从客户端访问。

Docker Server 接受 Docker-Client 的指令。

和虚拟机的区别

Docker所使用的容器化技术本质上属于虚拟化技术

提到虚拟化技术,最有名的就是虚拟机技术

虚拟机原理示意图

它有以下明显的缺点:

  • 资源占用多。启动虚拟机非常占内存,对电脑资源有不小的占用。
  • 冗余步骤多。启动虚拟机后,还需要进行一些步骤才能进入系统,效率比较低。
  • 启动很慢。由于虚拟机是虚拟化一整个系统,其启动时间会比较缓慢,一般都需要几分钟。

容器化原理示意图

它不是模拟的完整操作系统,而是基于操作系统封装成了一个个小的运行环境。

区别

传统虚拟机 Docker
虚拟内容 硬件 + 完整的操作系统 + 软件 APP + LIB
大小 笨重,通常几个 G 轻便几个 M 或 KB
启动速度 慢,分钟级 快,秒级

Docker 为什么比 VM 快

Docker 有着比 VM 更少的抽象层。

Docker 主要用的是宿主机的内核,而 VM 需要 Guest OS

新建容器的时候,Docker 不需要像 VM 一样重新加载一个操作系统内核,避免了引导的过程。

安装

关于 Docker 的安装在我之前的博文:Linux 12 yum方式安装Docker 已经介绍得很清楚,可以跳转查看。

命令

Docker 01 概述的更多相关文章

  1. Docker 前沿概述

    目录 Docker 前沿概述 什么是Docker? Docker的基本概念 容器(Container) -- 镜像运行时的实体 镜像(Image) -- 一个特殊的文件系统 仓库(Repository ...

  2. Docker基本原理概述

    Docker基本原理概述 Docker是一个用于开发,交付和运行应用程序的开放平台.Docker能够将应用程序与基础架构分开,从而可以快速交付软件.借助Docker,可以以与管理应用程序相同的方式来管 ...

  3. docker 网络概述及网络模式详解

    docker 网络概述及网络模式详解 1.网络概述 2.网络模式详解 1.网络概述: Docker 网络实现原理 Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥(docker0) ...

  4. Docker(1)--概述

    Docker概述 Docker是一个用于开发,交付和运行应用程序的开放平台.Docker使您能够将应用程序与基础架构分开,从而可以快速交付软件.借助Docker,您可以以与管理应用程序相同的方式来管理 ...

  5. 01 - 概述 VTK 6.0 迁移

    摘要 对vtk版本4和5的管道机制重新架架构的主要目的是:迁移数据对象和算法对象中的管道执行逻辑到一个新集合的类中,我们称这个集合类叫executives.分离数据和执行模型的代码后,可以双双简化修改 ...

  6. Docker 01 Introduction

    Docker的组成: Docker Engine,一个轻量级.强大的开源容器虚拟化平台,使用包含了工作流的虚拟化技术,帮助用户建立.并容器化一个应用. Docker Hub,提供的一个SaaS服务,用 ...

  7. Redis数据库 01概述| 五大数据类型

    1.NoSQL数据库简介 解决应用服务器的CPU和内存压力:解决数据库服务的IO压力: ----->>> ① session存在缓存数据库(完全在内存里),速度快且数据结构简单: 打 ...

  8. 001.Docker简介概述

    一 简介 Docker最初是dotCloud公司的一个内部项目,诞生于 2013 年初,由google公司开源的Go语言开发. Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可移 ...

  9. Docker 开发概述

    This page lists resources for application developers using Docker. Develop new apps on Docker If you ...

随机推荐

  1. 差分优化建边(Tax)

    [Luogu P6822PA2012]Tax] (http://www.luogu.com.cn/problem/P6822") All right. Let's go! 题目描述 给出一个 ...

  2. JavaSE_多线程入门 线程安全 死锁 状态 通讯 线程池

    1 多线程入门 1.1 多线程相关的概念 并发与并行 并行:在同一时刻,有多个任务在多个CPU上同时执行. 并发:在同一时刻,有多个任务在单个CPU上交替执行. 进程与线程 进程:就是操作系统中正在运 ...

  3. Redis集群搭建 三主三从

    Redis集群介绍 Redis 是一个开源的 key-value 存储系统,由于出众的性能,大部分互联网企业都用来做服务器端缓存.Redis在3.0版本之前只支持单实例模式 虽然支持主从模式,哨兵模式 ...

  4. 架构师必备:HBase行键设计与应用

    首先要回答一个问题,为何要使用HBase? 随着业务不断发展.数据量不断增大,MySQL数据库存在这些问题: MySQL支持的数据量为TB级,不能一直保留历史数据.而HBase支持的数据量为PB级,适 ...

  5. Spark读取elasticsearch数据指南

    最近要在 Spark job 中通过 Spark SQL 的方式读取 Elasticsearch 数据,踩了一些坑,总结于此. 环境说明 Spark job 的编写语言为 Scala,scala-li ...

  6. Spring Data JPA系列2:SpringBoot集成JPA详细教程,快速在项目中熟练使用JPA

    大家好,又见面了. 这是Spring Data JPA系列的第2篇,在上一篇<Spring Data JPA系列1:JDBC.ORM.JPA.Spring Data JPA,傻傻分不清楚?给你个 ...

  7. Docker容器搭建android编译环境

    Docker容器搭建android编译环境 目录 1 部署容器 1.1 手动部署 1.1.1 配置docker 1.1.2 启动容器 1.1.3 配置环境 1.2 Dockerfile 2 镜像管理 ...

  8. HBuilderX配置外部服务器(tomcat)查看编辑jsp界面

    HBuilderX配置外部服务器(tomcat)查看编辑jsp界面 一.第一种方法,通过启动本地tomcat,查看jsp 在tomcat的webapps目录下创建文件夹HBuilderX 打开HBui ...

  9. 用Bootstrap4写了一个WordPress主题Writing

    这是一个简洁的WordPress博客主题,为专注写作而设计. 本主题使用Bootstrap4框架开发. 主要功能 自适应: 标签云页面模板: 两栏设计: 全宽页面模板: 支持设置背景色和背景图片: 8 ...

  10. 静态代码块和数组工具类Arrays

    静态代码块 静态代码块:定义在成员位置,使用static修饰的代码块{ }. ~位置:类中方法外. ~执行:随着类的加载而执行且执行一次,优先于main方法和构造方法的执行 格式: public cl ...