一文了解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,并能够创建属于自己 ...
随机推荐
- Redis5种常用数据类型的使用以及内部编码
String 字符串类型是redis的最基本类型,首先无论值是什么数据类型,其键都是字符串,且其他数据类型的数据结构都是在字符串的基础上搭建的,相信读者能够体会到字符串在redis的地位是有多么的重要 ...
- canvas 实现简单的画板功能 1.0
canvas 实现自由画线,变换颜色.画笔大小,撤销上一步等简单功能 <!DOCTYPE html> <html lang="en"> <head&g ...
- Ubuntu20.04安装 maven并配置阿里源
Ubuntu20.04安装 maven并配置阿里源 sudo apt update sudo apt install maven #安装maven,默认安装路径为/usr/share/maven 添加 ...
- Serverless 在 SaaS 领域的最佳实践
作者 | 计缘 来源 | Serverless 公众号 随着互联网人口红利逐渐减弱,基于流量的增长已经放缓,互联网行业迫切需要找到一片足以承载自身持续增长的新蓝海,产业互联网正是这一宏大背景下的新趋势 ...
- Java多线程编程实战指南 核心篇 读书笔记
锁 volatile CAS final static 原子性保障 具备 具备 具备 不涉及 不涉及 可见性保障 具备 具备 不具备 不具备 具备① 有序性保证 具备 具备 不涉及 具备 具备② 上下 ...
- 【UE4 C++ 基础知识】<14> 多线程——AsyncTask
概念 AsyncTask AsyncTask 系统是一套基于线程池的异步任务处理系统.每创建一个AsyncTas,都会被加入到线程池中进行执行 AsyncTask 泛指 FAsyncTask 和 FA ...
- Codeforces1514B
问题描述 给你两个数n,k,问可以构造多少n个最大位数为k数按位与为0并且这n个数加起来最大的合法序列,答案对1e9 + 7取模. 思路分析 首先我们考虑这n个数按位与以后为0这个条件:我们可以知道, ...
- 【二食堂】Alpha - Scrum Meeting 10
Scrum Meeting 10 例会时间:4.20 18:00~18:20 进度情况 组员 昨日进度 今日任务 李健 1. 与柴博合作完成登录注册页面issue 继续完成登录注册页面issue 柴博 ...
- 浅谈如何爆踩TLEcoders
对付一些速度比老奶奶都慢的评测姬, 除了超级小的常数,往往还不得不使用一些不算办法的办法 比如说这个让人无语的$ACcoders$的评测姬, 当我们感到代码已经无法再卡常的时候,对人生已经近乎绝望的时 ...
- stm32f103中断学习总结
一.NVIC 介绍 NVIC 英文全称是 Nested Vectored Interrupt Controller,中文意思就是嵌套向量中断控制器,它属于 M3 内核的一个外设,控制着芯片的中断相关功 ...