如何通俗解释Docker是什么?
Docker的思想来自于集装箱,集装箱解决了什么问题?在一艘大船上,可以把货物规整的摆放起来。并且各种各样的货物被集装箱标准化了,集装箱和集装箱之间不会互相影响。那么我就不需要专门运送水果的船和专门运送化学品的船了。只要这些货物在集装箱里封装的好好的,那我就可以用一艘大船把他们都运走。
docker就是类似的理念。现在都流行云计算了,云计算就好比大货轮。docker就是集装箱。
1.不同的应用程序可能会有不同的应用环境,比如.net开发的网站和php开发的网站依赖的软件就不一样,如果把他们依赖的软件都安装在一个服务器上就要调试很久,而且很麻烦,还会造成一些冲突。比如IIS和Apache访问端口冲突。这个时候你就要隔离.net开发的网站和php开发的网站。常规来讲,我们可以在服务器上创建不同的虚拟机在不同的虚拟机上放置不同的应用,但是虚拟机开销比较高。docker可以实现虚拟机隔离应用环境的功能,并且开销比虚拟机小,小就意味着省钱了。
2.你开发软件的时候用的是Ubuntu,但是运维管理的都是centos,运维在把你的软件从开发环境转移到生产环境的时候就会遇到一些Ubuntu转centos的问题,比如:有个特殊版本的数据库,只有Ubuntu支持,centos不支持,在转移的过程当中运维就得想办法解决这样的问题。这时候要是有docker你就可以把开发环境直接封装转移给运维,运维直接部署你给他的docker就可以了。而且部署速度快。
3.在服务器负载方面,如果你单独开一个虚拟机,那么虚拟机会占用空闲内存的,docker部署的话,这些内存就会利用起来。
总之docker就是集装箱原理。
作者:刘允鹏
链接:http://www.zhihu.com/question/28300645/answer/67707287
虚拟机 隔离得好,但是代价大:同样的物理机,同时运行10个虚拟机,可能就力不从心了
docker相当于轻量级的虚拟机,放弃某些隔离效果换来低代价:同样的物理机,同时运行成千上万个docker都可能,而且启动非常快(虚拟机都有一个“硬件”自检、OS启动的过程;docker基本无这个过程,因为是直接运行在物理机的OS上的)
但虚拟机可以在OSa上同时运行出n个OSa和m个OSb、p个OSc。。。
而docker只能在OSa上同时运行x个OSa(虽然x>>n+m+p+...) 作者:海涛
链接:http://www.zhihu.com/question/28300645/answer/54332980
用Docker的logo来解释,鲸鱼和集装箱&
lt;
img src=https://www.it610.com/article/"
https://pic4.zhimg.com/5d2cabafe63f33389c8a5c8ae1e576bb_b.jpg"
data-rawwidth="
932"
data-rawheight="
486"
class="
origin_image zh-lightbox-thumb"
width="
932"
data-original="
https://pic4.zhimg.com/5d2cabafe63f33389c8a5c8ae1e576bb_r.jpg"
&
gt;
文章图片
那个大鲸鱼(或者是货轮)就是操作系统
把要交付的应用程序看成是各种货物,原本要将各种各样形状、尺寸不同的货物放到大鲸鱼上,你得为每件货物考虑怎么安放(就是应用程序配套的环境),还得考虑货物和货物是否能叠起来(应用程序依赖的环境是否会冲突)。
现在使用了集装箱(容器)把每件货物都放到集装箱里,这样大鲸鱼可以用同样地方式安放、堆叠集装了,省事省力。
Docker就是这整套机制啦
作者:周宇刚
链接:http://www.zhihu.com/question/28300645/answer/50922662
用Docker的logo来解释,鲸鱼和集装箱&
lt;
img src=https://www.it610.com/article/"
https://pic4.zhimg.com/5d2cabafe63f33389c8a5c8ae1e576bb_b.jpg"
data-rawwidth="
932"
data-rawheight="
486"
class="
origin_image zh-lightbox-thumb"
width="
932"
data-original="
https://pic4.zhimg.com/5d2cabafe63f33389c8a5c8ae1e576bb_r.jpg"
&
gt;
文章图片
那个大鲸鱼(或者是货轮)就是操作系统
把要交付的应用程序看成是各种货物,原本要将各种各样形状、尺寸不同的货物放到大鲸鱼上,你得为每件货物考虑怎么安放(就是应用程序配套的环境),还得考虑货物和货物是否能叠起来(应用程序依赖的环境是否会冲突)。
现在使用了集装箱(容器)把每件货物都放到集装箱里,这样大鲸鱼可以用同样地方式安放、堆叠集装了,省事省力。
Docker就是这整套机制啦
作者:周宇刚
链接:http://www.zhihu.com/question/28300645/answer/50922662
【大话Docker】
作者:刘允鹏
链接:http://www.zhihu.com/question/28300645/answer/67707287
推荐阅读
- 微服务|Eureka的高可用以及服务提供者、服务消费者集群之间的调用方式
- 开源项目|20个基于SpringBoot搭建的开源项目,总有一个你会感兴趣
- Spring|Spring中Bean的命名问题及ref和idref之间的区别