一文了解Docker基本概念
一、何为Docker
Docker 是一个用于开发、交付和运行应用程序的开放平台,Docker 使您能够将应用程序与基础环境分开,以便您可以快速交付软件。借用百度百科的话来说,Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。
对于开发者来说,开发人员可以利用docker开发和运行应用程序
对于运维人员来说,docker可以部署和管理应用程序。

Docker和容器的关系就类似与VMware和虚拟机的关系,Docker类似于VMware,容器类似于虚拟机。
二、为什么用Docker
有人会问,既然Docker以及容器分别与VMware和虚拟机类似,那么为什么还会用到Docker,他们之间有什么差别?
1、通过上图可以发现,每个虚拟机下,都要安装一个操作系统,而容器是不需要的,它只需要软件工作所需的库资源和设置,他是直接运行在操作系统上面,一个操作系统之上可以有多个容器运行,容器不仅比虚拟机更轻量,更快速,还起到了与虚拟机差不多的功能,并且保证了在任何环境中的软件能够始终如一的运行。
2、借助Docker,你可以像管理应用程序一样管理基础架构
3、借助Docker可以实现程序的快速部署和分发,以及降低配置开发环境、生产环境复杂程度和成本。
4、更高效的利用系统资源 由于容器不需要进行硬件虚拟以及运行完整操作系统等额外开销,Docker 对系统资源的利用 率更高。无论是应用执行速度、内存损耗或者文件存储速度,都要比传统虚拟机技术更高效。因此,相比虚拟机技术,一个相同配置的主机,往往可以运行更多数量的应用。
5、更快速的启动时间 传统的虚拟机技术启动应用服务往往需要数分钟,而 Docker 容器应用,由于直接运行于宿主 内核,无需启动完整的操作系统,因此可以做到秒级、甚至毫秒级的启动时间。大大的节约了开发、测试、部署的时间。
三、Docker架构

Docker是一个客户端-服务端(CS)应用程序
服务端:一个长时间运行的守护进程(Docker Daemon),Docker Daemon侦听 Docker API 请求并管理 Docker 对象,例如镜像、容器、网络和卷。
注:不过现在越来越多的功能早已从daemon中拆解出来并被模块化,感兴趣的小伙伴可以去多多了解。
客户端:命令行接口CLI,Docker 用户与 Docker 交互的主要方式。
通信:Docker 客户端和守护进程使用 REST API、UNIX 套接字或网络接口进行通信
四、Docker对象

镜像:对于 Linux 而言,内核启动后,会挂载 root 文件系统为其提供用户空间支持。而 Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含
了完整的一套 Ubuntu 16.04 最小系统的 root 文件 系统。Docker镜像(Image)是一个只读模板,一个Docker的可执行文件,镜像可以用来创建Docker容器,一个镜像可以创建很多容
器。镜像在构建之后其内容不可改变。
Docker镜像由一层层layer组成,我们称之为镜像层,最后一层也是最上面的一层我们称之为容器层
镜像构建时,会一层层构建,前一层是后一层的基础。每一层构建完就不会再发生改变,后一层上的任何改变只发生在自己这一层。比如,删除前一层文件的操作,实际不是真的删
除前一层的文件,而是仅在当前层标记为该文件已删除。在最终容器运行的时候,虽然不会看到这个文件,但是实际上该文件会一直跟随镜像。
每一层都对应这DockerFile中的一条指令,通常最后一层为CMD层或者ENTRYPOINT层,这一层是R/W的,即容器层。
Docker镜像采用这种分层机构最大的一个好处就是共享资源。
比如:有多个镜像都从相同的base镜像构建而来,那么宿主机只需在磁盘上保存一份base镜像,同时内存中也只需要加载一份base镜像,就可以为所有容器服务了。而且镜像的每一
层都可以被共享。
容器:Docker利用容器(Container)独立运行的一个或一组应用。容器是镜像创建的运行实例。
它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。
可以把容器看作是一个简易版的Linux环境(包括root权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。
容器的定义和镜像几乎一模一样,也是一堆层的统一视角,唯一区别在于容器的最上面那一层可读可写。
每一个容器运行时,是以镜像为基础层, 在其上创建一个当前容器的存储层,我们可以称这个为容器运行时读写而准备的存储层为容 器存储层。 容器存储层的生存周期和容器一
样,容器消亡时,容器存储层也随之消亡。因此,任何保存 于容器存储层的信息都会随容器删除而丢失。
网络:外部或者容器间访问的网络方式,如host模式,bridge模式
数据卷:容器与宿主机之间、容器与容器之间共享存储方式,类似于虚拟机与主机之间的共享文件目录。
Docker仓库
仓库(Repository)是集中存放镜像文件的场所。
仓库分为私有仓库和公有仓库两种形式
DockerHub类似与github,不过前者是存放镜像,后者是存放代码
五、Docker底层使用的技术
1、Docker使用go语言来实现的
2、Docker利用Linux内核的几个特性来实现功能
2.1、利用linux的命名空间(NameSpaces)为Docker容器提供系统层面的隔离
- 进程号隔离:每一个容器内运行的第一个进程,进程号总是从1开始;
- 网络隔离:容器内的网络与宿主机或其他容器的网络是隔离的,分开的;
- 进程隔离:容器中的进程与宿主机或其他容器中的进程是相互隔离的,通信需要借助网络;
- 文件系统挂载隔离:容器拥有自己单独的工作目录;
- 内核以及系统版本号隔离:容器查看内核版本号或系统版本号时,查看的是容器的,而非宿主机的。
2.2、利用linux控制组(Control Groups)为Docker提供硬件层面的隔离
- 控制组能控制应用程序所使用的硬件资源;
- 基于该性质,控制组帮助docker引擎将硬件资源共享给容器使用,并且加以约束和限制。如控制容器所使用的内存大小;
- 控制组提供了很多有用的特性;以及确保各个容器可以公平地分享主机的内存、CPU、磁盘 IO 等 资源;
- 控制组确保了当容器内的资源使用产生压力时不会连累主机系统。
2.3、利用Linux的联合文件系统(Union File Systems)利用分层(layer)思想管理镜像和容器
- 这也意味着Docker只能在Linux上运行之所以能够在windows和Mac上运行Docker,其实本质上是借助了虚拟化技术
2.4容器格式
- 最初,Docker 采用了 LXC 中的容器格式。从 0.7 版本以后开始去除 LXC,转而使用自行开发的 libcontainer,从 1.11 开始,则进一步演进为使用 runC 和 containerd。
一文了解Docker基本概念的更多相关文章
- Docker基本概念及架构
一.Docker基本概念 Docker是一个开源的容器引擎,基于Go 语言并遵从 Apache2.0 协议开源.Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布 ...
- Docker教程:docker的概念及安装
http://blog.csdn.net/pipisorry/article/details/50754385 Why docker 对于运维来说,Docker提供了一种可移植的标准化部署过程,使得规 ...
- 菜鸟系列docker——docker基本概念(1)
docker基本概念 1.准备 这里先介绍容器技术,后续再介绍docker.docker是容器的一种,除docker以外,还存在coreos.不过在当前趋势下容器和docker基本上可以划为等号了. ...
- docker核心概念(镜像、容器、仓库)及基本操作
概要 docker是一种linux容器技术.容器有效的将由单个操作系统挂管理的资源划分到孤立的组中,以便更好的在组之间平衡有冲突的资源使用需求.可简单理解为一种沙盒 .每个容器内运行一个应用,不同的容 ...
- Docker 核心概念、安装、端口映射及常用操作命令,详细到令人发指。
Docker简介 Docker是开源应用容器引擎,轻量级容器技术. 基于Go语言,并遵循Apache2.0协议开源 Docker可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...
- Docker 基础概念科普 和 常用操作介绍
Docker 基础概念 Docker是什么? Docker的思想来自于集装箱,集装箱解决了:在一艘大船上,可以把货物规整的摆放起来.并且各种各样的货物被集装箱标准化了,集装箱和集装箱之 ...
- 后端技术杂谈9:先搞懂Docker核心概念吧
本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...
- 一文了解Docker容器技术的操作
一文了解Docker容器技术的操作 前言一.Docker是什么二.Docker的安装及测试Docker的安装Docker的Hello world测试三.Docker的常见操作镜像的基本操作容器的基本操 ...
- docker基本概念,创建、起动实例,保存自定义镜像等常用操作
14年docker火了一阵,当时自学整理了一份文档,后来冷落了. 现在发现很多同事还是想学习docker,但无从下手,所以重新整理了这篇分享,10分钟就可以带你彻底理解docker,并能够创建属于自己 ...
随机推荐
- 11.4.1 LVS-DR
Virtual Server via Direct Routing(VS-DR): 用直接路由技术实现虚拟服务器。当参与集群的计算机和作为控制管理的计算机在同一个网段时可以用此方法,控制管理的计算机接 ...
- Docker小白到实战之Docker Compose在手,一键足矣
前言 Docker可以将应用程序及环境很方便的以容器的形式启动,但当应用程序依赖的服务比较多,或是遇到一个大系统拆分的服务很多时,如果还一个一个的根据镜像启动容器,那就有点累人了,到这有很多小伙伴会说 ...
- 4 个场景揭秘,如何低成本让容器化应用 Serverless 化?
作者 | changshuai FaaS 的门槛 Serverless 形态的云服务帮助开发者承担了大量复杂的扩缩容.运维.容量规划.云产品打通集成等责任,使得开发者可以专注业务逻辑.提高交付速度 ( ...
- 题解 CF1103E Radix sum
题目传送门 题目大意 给出一个\(n\)个数的序列\(a_{1,2,..,n}\),可以选\(n\)次,每次可以选与上次选的相同的数,问对于\(\forall p\in[0,n-1]\)满足选出来的数 ...
- pycharm输入代码后,没有补全提示
安装pycharm后,输入代码后,没有补全提示 首先检查是否关闭了代码提示,如下图,将红框中"Power Save Mode"前的勾去掉 第二步,如果在输入某些代码时还是没有补全提 ...
- C#并行编程:Parallel的使用
前言:在C#的System.Threading.Tasks 命名空间中有一个静态的并行类:Parallel,封装了Task的使用,对于执行大量任务提供了非常简便的操作.下面对他的使用进行介绍. 本篇内 ...
- 用C++生成solidity语言描述的buchi自动机的初级经验
我的项目rvtool(https://github.com/Zeraka/rvtool)中增加了生成solidity语言格式的监控器的模块. solidity特殊之处在于,它是运行在以太坊虚拟机环境中 ...
- windows环境下基于pycharm安装Redis出现的两个错误解决方案
说明:下面给出的两个链接是解决安装和使用Redis的时候遇到的两个问题参考的博客网址,本文有解释不清楚的地方可以原博客查看,侵权删! Q1参考链接-https://blog.csdn.net/maqu ...
- 前端HTML元素的类型名称
<div id="content" class="para" style="width:800px;"> <p>He ...
- HCNP Routing&Switching之BGP防环机制和路由聚合
前文我们了解了BGP路由宣告相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15440860.html:今天我们来聊一聊BGP防环机制和路由聚合相关话题 ...