Docker 01 概述
参考源
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://docs.docker.com/docker-for-windows/
命令:https://docs.docker.com/engine/reference/run/
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 概述的更多相关文章
- Docker 前沿概述
目录 Docker 前沿概述 什么是Docker? Docker的基本概念 容器(Container) -- 镜像运行时的实体 镜像(Image) -- 一个特殊的文件系统 仓库(Repository ...
- Docker基本原理概述
Docker基本原理概述 Docker是一个用于开发,交付和运行应用程序的开放平台.Docker能够将应用程序与基础架构分开,从而可以快速交付软件.借助Docker,可以以与管理应用程序相同的方式来管 ...
- docker 网络概述及网络模式详解
docker 网络概述及网络模式详解 1.网络概述 2.网络模式详解 1.网络概述: Docker 网络实现原理 Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥(docker0) ...
- Docker(1)--概述
Docker概述 Docker是一个用于开发,交付和运行应用程序的开放平台.Docker使您能够将应用程序与基础架构分开,从而可以快速交付软件.借助Docker,您可以以与管理应用程序相同的方式来管理 ...
- 01 - 概述 VTK 6.0 迁移
摘要 对vtk版本4和5的管道机制重新架架构的主要目的是:迁移数据对象和算法对象中的管道执行逻辑到一个新集合的类中,我们称这个集合类叫executives.分离数据和执行模型的代码后,可以双双简化修改 ...
- Docker 01 Introduction
Docker的组成: Docker Engine,一个轻量级.强大的开源容器虚拟化平台,使用包含了工作流的虚拟化技术,帮助用户建立.并容器化一个应用. Docker Hub,提供的一个SaaS服务,用 ...
- Redis数据库 01概述| 五大数据类型
1.NoSQL数据库简介 解决应用服务器的CPU和内存压力:解决数据库服务的IO压力: ----->>> ① session存在缓存数据库(完全在内存里),速度快且数据结构简单: 打 ...
- 001.Docker简介概述
一 简介 Docker最初是dotCloud公司的一个内部项目,诞生于 2013 年初,由google公司开源的Go语言开发. Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可移 ...
- Docker 开发概述
This page lists resources for application developers using Docker. Develop new apps on Docker If you ...
随机推荐
- 国外卡组织的 交换费-interchangefee(发卡行服务费) 和 银联对比
本文地址:https://www.cnblogs.com/hchengmx/p/15170391.html 1. 交换费(interchangefee)介绍 2. MasterCard 万事达卡 &a ...
- [WUSTCTF2020]朴实无华-1
1.打开连接只有如下界面: 2.用bp抓包分析包内数据,未发现有用的信息: 3.进行目录扫描,获得robots.txt文件并进行访问: 4.访问/fAke_f1agggg.ph ...
- linux shell的配置文件执行顺序
shell配置文件的作用:初始化环境变量.设置命令提示符.指定系统命令路径等 shell配置文件分类: (1)系统级别配置文件: /etc下,比如/etc/profile./etc/bashrc (2 ...
- Consider defining a bean of type 'redis.clients.jedis.JedisPool' in your configuration.
报错信息 原因是没有Jedispool没有注入 import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml ...
- Neural Networks
神经网络能够使用torch.nn包构建神经网络. 现在你已经对autogard有了初步的了解,nn基于autograd来定义模型并进行微分.一个nn.Module包含层,和一个forward(inpu ...
- SELECT 的6大子句
SELECT 6大子句的顺序: SELECT selection_list /*要查询的列名称*/, 结果的字段列表 FROM table_list /*要查询的表名称*/, 后面跟表,视图,多行多列 ...
- javascript基本属性访问对象的属性和方法
var myName = "Shelley"; //字符串基本类型 alert(myName.length); //隐式创建String对象,数值与myName相同,并执行len ...
- SLSA 框架与软件供应链安全防护
随着软件供应链攻击浪潮愈演愈烈,Google 发布了一系列指南来确保软件包的完整性,旨在防止影响软件供应链的未经授权的代码修改.新的 Google SLSA 框架(Supply-chain Level ...
- 虚拟机安装Centos7.5详细教程
VMware15.5虚拟机安装CentOS7.5详细教程 (前言)软件下载 需要VMware15.5软件和密匙的小伙伴可以从此地址下载:https://pan.baidu.com/s/1A8H ...
- 字节输入流_InputStream类&FileInputStream类介绍和字节输入流读取字节数据
java.io.InputStream:字节输入流 此抽象类是表示字节输入流的所有类的超类 定义了所有子类共性的方法: int read()从输入流中读取数据的下一个字节 int read(byte[ ...