docker也一直发展
docker也一直发展。但本答案仅仅作为向新人介绍docker的入门文章的话,在大方向上还是没问题的。本文仅仅是个docker入门介绍文章,用比较宏大的叙事来描述docker的面貌,如果想了解更细节或者更深入的东西,还是需要去深入学习官方文档等内容。答案正文:---# 难懂的docker学术式定义Docker is an open-source project that automates the deployment of applications inside software containers, by providing an additional layer of abstraction and automation of operating-system-level virtualization on Linux. Docker uses the resource isolation features of the Linux kernel such as cgroups and kernel namespaces, and a union-capable filesystem such as aufs and others to allow independent “containers” to run within a single Linux instance, avoiding the overhead of starting and maintaining virtual machines.Docker是一个开放源代码软件项目,让应用程序布署在软件容器下的工作可以自动化进行,借此在Linux操作系统上,提供一个额外的软件抽象层,以及操作系统层虚拟化的自动管理机制。Docker利用Linux核心中的资源分离机制,例如cgroups,以及Linux核心命名空间(name space),来建立独立的软件容器(containers)。这可以在单一Linux实体下运作,避免启动一个虚拟机器造成的额外负担。——摘自维基百科这个定义真是学院派的不能再学院派了,一般人通过这个充满专业名词的定义,能模糊地了解docker是种虚拟化工具,可以实现简化部署之类功能,但是并不能清楚地理解它到底牛逼在什么地方。## 如何搞懂一个陌生的概念?要搞明白docker的概念只看定义远远不够,还需要通过其他方式来认识它,一般来说有三种:第一种:在长期使用docker的过程中,逐渐体会到其优势(放到具体场景中认识)第二种:通过和一些已经熟悉的概念对比来认识(比如虚拟机)上述两种方法都要求掌握相当多的软件虚拟化知识,但是对于一个从未接触过docker,甚至对部署都不是很了解,也没时间去研究docker的新人,应该怎么快速理解docker的核心优势呢?第三种:借助于隐喻。如果你不清楚隐喻的概念,这里有一篇文章单独介绍:隐喻 。如果不想了解,可以将隐喻简单理解为类比:借助于另一个更容易认识的概念来映射新概念。# docker的隐喻「docker」字面意思是「码头工人」,这个名字应该是官方深思熟虑之后的结果,本身就带有很强的隐喻性质:借用了一个在真实世界中已经成熟的体系——全球物流系统,来映射docker在软件领域中起到的作用。在全球物流系统中,一个非常重要的发明就是集装箱。##集装箱重要在哪里?为了理解这件事情,可以先考察一下集装箱出现之前的物流情况:货物从工厂生产出来之后装箱,然后一箱箱的搬到卡车上,然后再一箱箱卸下来,一箱箱送上火车,运送到码头附近的火车站,再一箱箱卸下来,装上卡车,拉到货轮上,再一箱一箱的装上去…可以看出在整个流程中,大量的时间,人力 ,物力浪费在了中间的装卸上。在物流系统里,由于路程和运输工具速度的限制,货物真正在路上的时间是一定的,在交通技术得到改善之前,这个时间也很难去缩短,于是「货物装卸时间」就成了物流系统中的瓶颈。这个瓶颈在集装箱出现之后得到了很大的改善。集装箱重要在它提供了一种通用的封装货物的标准规格(尺寸,外形符合统一标准),这样就产生了一些巨大的优点:只需要在运输前一次性封装,集装箱就可以放上火车,卡车,拉到码头,直接放在货船上;卸船之后直接再放上火车,卡车,运送到目的地。而且由于集装箱符合统一标准,整个流程非常容易机械化,这引发了以集装箱为中心的整个全球物流的标准化进程,进而节省了大量的资源,物流成本迅速下降,促进了全球资源的流动与重新配置。##docker(码头工人)正是借用了集装箱的隐喻docker就像往集装箱里装货物的码头工人那样,它把应用打包成具有某种标准规格的集装箱,用计算机领域的语言来说,这种按照一定规格封装的集装箱叫「镜像」。其实就是将你原来的代码添加点额外的内容,格式之类的,生产出来的一个符合某种标准的东西。集装箱减少了货物的运输工作量,那docker镜像又有什么相似的优势呢?同样可以先看看docker出现之前的应用部署是情况。### docker出现之前的部署情况在docker出现之前,比如说要部署一个django(一个流行的python web服务框架)应用,要做哪些事情?首先得有个python环境,比如这个要部署的应用基于python3,而你机器上是python2,那ok,先装个python3吧,一看装起来还挺麻烦,要先装各种依赖,还要解决一些可能的冲突,没办法硬着头皮上吧。装完python之后,发现还要装mysql,还用了redis。没办法,继续下载,安装,配置。费了九牛二虎之力终于搞完了,一天就这么过去了。啥?你告诉我原来的服务器不用了,要换一台服务器?我靠,那重新来一遍吧。啥?你说咱们的基础应用做的太好,要进行推广,需要指导其他厂商部署?我选择狗带上面的描述可能有些夸张,但也不是非常罕见。在docker出现之前,各种安装、配置环境正是运维人员经常做的事情之一,而且在重复工作上浪费了巨大的资源。###docker出现之后####标准的交付件前面提到docker最像集装箱的地方,就是它是软件交付领域的一种「标准化」,这种标准化的具体产物,简单来说就是「镜像(image)」。「镜像」这个词说实话太玄乎,当然对应的原文「image」本身也挺玄乎的。原因是它根据一些场景引申了本来的含义。image本身是「画像,映像」的意思,又有「现实物体的抽象描绘」的意思,而且画像本身可以很容易的复制,后来又有了「原画像复制品」一类的意思。再后来直接就拿来表示光盘镜像(很容易复制的存储影像的东西,只不过画像是画在纸上,但这种影像以数字形式存在于光盘上)。当然「镜像」在汉语中就有「复制品」的含义,只不过加入了汉字独有的意境,显得玄乎,朦胧了。在docker中镜像是指,把你的应用按照docker规定的格式封装成一种具有某种标准规格的东西(就像集装箱把你的货物封装起来类似)。形象的说,就是把你的应用按照一定的格式抽象的画了个画像。在docker中镜像是无法直接运行的,我猜想这并不是技术上的原因,而是出于工程设计的考虑。因为一般来说,一个软件的某个具体版本只会打包成一个镜像, 如果镜像可以配置,运行的话,在使用过程中很可能会对镜像造成破坏。那怎么样避免镜像损坏的问题呢?就是再加一层,相当于分身术,只要本尊没问题,分身怎么扑街都不会真正的跪掉。多加的这一层分身,就叫容器(container),这个名字也挺形象,它就像个盒子一样,你的应用在里面运行,而且多了一层安全机制。你想使用服务或把你的应用跑起来的话,只需要基于镜像新创建一个容器就可以了(一条命令搞定),而镜像还放在那里不动,没办法,金贵嘛。#### Docker 究竟简化了什么东西?docker在部署过程中,将安装,配置等重复的部分自动化完成。只需要在第一次部署时,构建完可用的docker镜像(装好集装箱),在以后使用中,短短的几行命令就可以直接拉取镜像,根据这个镜像创建出一个容器,把服务跑起来了。所需要的仅仅是安装了docker的服务器,一个Dockerfile文件(装箱清单),以及比较流畅的网络而已,真可谓『一次构建,到处部署』。需要python3环境?直接在Dockerfile(装箱清单)中加入: from python:3.x 搞定。需要迁移服务器? 直接把Dockerfile,备份数据拷贝到新服务器,几条命令又搞定需要作为服务给别人使用?Dockerfile即是最清晰的部署文档,维护一个官方镜像即可,谁需要就直接拉下来几条命令部署上就行了。到这里你可能更能明白,docker不像传统的软件交付方式那样,只把代码以及说明文档之类的给你就完了,而是直接给你一个像集装箱那样的标准docker货件,这个标准件不仅包括了应用代码本身,还包括了代码运行需要的OS等整体依赖环境。于是,谁想用我的服务,直接拉取镜像,实例化一个容器就可以了,不再像之前那样有繁复的安装过程————这些都有人给你做过了。#### 当然docker的优点不止于此基于一件核心事物的「标准化」有时候可以做更多的事情,就像集装箱带来的「标准化」不仅限于集装箱本身,同时还包括了运输器械,物流管理方法等在内的整个领域的标准化和效率的提高。再远的标准化案例比如自行车上的螺丝,轮胎等都有全球通用的标准,这些核心标准一经建立就对行业产生了深远的影响。docker也类似,一旦这种虚拟化封装标准建立起来之后,就可以基于标准件和相应的管理方式做更多的事情。随便举一些例子:1.统一的管理服务使用docker部署的应用,都会在docker的管理范围之内。这也是docker的另一个优点(第一个是标准化),它提供了一种隔离的空间,把服务器上零散的部署应用集中起来进行管理。比如未使用docker的时候,一个服务器上部署了n多服务,有mysql,redis,rabbitmq...。有一天服务器突然断电重启了,那些没有设置自动重启的应用,那些重启出问题的应用,那些你甚至都不知道隐藏在某个角落里的重要应用没启动成功….使用docker后,一眼就可以看出那些应用正常启动了,那些应用又出问题了,接下来只用有条不紊的处理就ok了。2.持续交付上的应用持续交付有一些超出范围,自己去寻找答案吧3.弹性计算也就是根据需要,动态地添加新的应用服务,在不需要时收回服务器资源,docker的标准化让这种弹性能力得到了更好的应用。# 最后,关于docker的一个误解很多人说docker改变了运维世界,这句话是从群体角度来说的,是统计学意义上的改变,像mysql,python这样被大规模使用的基础应用,docker化之后为整个群体所节省的时间是非常巨大的。有人可能会问,我只有一台服务器,也不太可能会迁移。我的python服务,mysql服务,只需要部署一次,就可以在以后重复使用了。那这样docker对于我来说还有优势吗?毕竟docker也是有学习成本的。如果你确信你的应用都是一次性的,而且只提供给自己使用,那么docker在这种场景下的优势不是特别明显:即便是docker,最初的构建也是需要有人做的,这和直接在机器上部署一次的工作量差不多。也就是说,docker并不能把部署的工作「减少为0」,比较好的情况下是「基本减少为1」
docker也一直发展的更多相关文章
- 关于docker
摘要: 最近很多阿里内部的同学和客户私信来咨询如何学习 Docker 技术.为此,我们列了一个路线图供大家学习Docker和阿里云容器服务.这个列表包含了一些社区的优秀资料和我们的原创文章.我们会随着 ...
- 《第一本docker书》—— 读后总结
关于docker 这本书其实并没有读完,只不过最近工作比较繁忙,也无心再看这些用不到的书.以后要是工作需要,再仔细学习吧. 这次的阅读算是达到目的了,对docker有了一定的了解.它的作用.意义以及大 ...
- Docker对普通开发者的用处(转)
有些开发者可能还是不明白 Docker 对自己到底有多大的用处,因此翻译 Docker 个人用例 这篇文章中来介绍 Docker 在普通开发者开发过程中的用例. Docker 如今赢得了许多关注,很多 ...
- 【云计算】docker前世今生
下一代云计算模式:Docker正掀起个性化商业革命 作者: 吴宁川 来源: ITValue 发布时间: 2015-09-20 10:41 阅读: 12976 次 推荐: 24 ...
- 下一代云计算模式:Docker正掀起个性化商业革命
作者: 吴宁川 来源: ITValue 发布时间: 2015-09-20 10:41 阅读: 10008 次 推荐: 16 原文链接 [收藏] 文/ITValue 记者吴宁川 从 20 ...
- Docker背后的容器管理——Libcontainer深度解析
Libcontainer 是Docker中用于容器管理的包,它基于Go语言实现,通过管理namespaces.cgroups.capabilities以及文件系统来进行容器控制.你可以使用Libcon ...
- docker 现实---中小企业docker环境结构(五)
docker对于中小企业,设定paas他没有足够的能量,没有必要为,个人二手sandbox实用性和小点.我个人觉得,中小企业可以使用docker要规范发展.测试.生产环境. 他画了一个简单的图表: d ...
- 【译文】什么是Docker
What is Docker? By Tim Butler • 14 May 2015 • https://www.conetix.com.au/blog/what-is-docker Unless ...
- Docker 网络之进阶篇
笔者在<Docker 基础 : 网络配置>一文中简单介绍了容器网络的基本用法,当时网络的基本使用方式还处于 --link 阶段.时过境迁,随着 docker 的快速发展,其网络架构也在不断 ...
- 从头认识一下docker-附带asp.net core程序的docker化部署
从头认识一下docker-附带asp.net core程序的docker化部署 简介 在计算机技术日新月异的今天, Docker 在国内发展的如火如荼,特别是在一线互联网公司, Docker 的使用是 ...
随机推荐
- HTTP协议超级详解【转载】
HTTP协议简介 超文本传输协议(英文:HyperText Transfer Protocol,缩写:HTTP)是一种用于分布式.协作式和超媒体信息系统的应用层协议.HTTP是万维网的数据通信的基础. ...
- RocketMQ(2)---实现分布式事务原理
分布式事务(3)-RocketMQ实现分布式事务原理 之前讲过有关分布式事务2PC.3PC.TCC的理论知识,博客地址: 1.分布式事务(1)---2PC和3PC原理 2.分布式事务(2)---TCC ...
- docker没有vi不能执行yum报Device or resource busy
最近在使用docker的过程中发现一个问题,就是想用vim编辑器编辑一个文件,发现连vi都没有. 于是想到一个办法用docker cp来解决问题: 首先执行docker ps -a查看容器的id 然后 ...
- 告别虚拟机!WSL2安装配置教程!!!
作者:SkyXZ CSDN:SkyXZ--CSDN博客 博客园:SkyXZ - 博客园 由于Linux的系统的稳定以及在环境管理方面的优越性,同时Linux对于ROS系统的独占,很多时候我们都乐意在L ...
- 【分享】 100+ 套开源大数据可视化大屏Html5模板,全网最炫!
今天给大家分享 100+ 套开源大数据可视化炫酷大屏Html5模板,全网最新.最多.最全.最酷.最炫的大数据可视化模板! 项目介绍 BigDataView提供了100+套大数据可视化炫酷大屏Html5 ...
- 基于MPC的快速transformer安全推理框架
论文:一种基于安全多方计算的快速Transformer安全推理方案-刘伟欣 摘要 数据隐私泄露问题:当前Transformer推理应用中用户的数据会被泄露给模型提供方 安全推理方法:基于MPC实现Tr ...
- dart集合list方法详解
List数组有两种声明方式: 01==>List 常用的属性==> length 计算数组的长度 reversed 数组翻转 isEmpty 是否为空 isNotEmpty 是否不为空 L ...
- HPC中常见的调度器介绍
本文分享自天翼云开发者社区<HPC中常见的调度器介绍> 作者:土豆炒肉丝 在高性能计算(HPC)环境中,调度器是负责管理和分配计算资源(如计算节点.处理器核心.内存等)给待执行任务的重要组 ...
- 爬虫基础知识及scrapy框架使用和基本原理
爬虫 一.异步IO 线程:线程是计算机中工作的最小单元 IO请求(IO密集型)时多线程更好,计算密集型进程并发最好,IO请求不涉及CPU 自定义线程池 进程:进程默认有主线程,可以有多线程共存,并 ...
- DBeaver出现“Public Key Retrieval is not allowed”错误的解决办法
1.问题描述 我们在使用DBeaver连接MySql的时候,可能会出现"Public Key Retrieval is not allowed"的错误提示,如下图所示: 2.解决办 ...