【Docker】一文趣谈Docker
《RabbitMQ》《Spring》《SpringMVC》《项目实战》
文章目录
- 前言
- 一、Docker是什么
- Docker历史
- 二、Docker为什么会出现
- 三、Docker能做什么
- 总结
前言
学习一门技术首先就要了解这个技术的是做什么的,为什么会出现,才能更好的学习与理解。
一、Docker是什么
- Docker是一个容器。
- 容器一词的英文是container,其实container还有集装箱的意思,集装箱绝对是很了不起的一项发明,大大降低了海洋贸易等运输成本。让我们来看看集装箱的好处:
- 集装箱内物品之间相互隔离
- 长期反复使用
- 快速装载和卸载
- 规格标准,在港口和船上都可以摆放,极大利用空间
- 而Docker就如同一个集装箱,大家可以看到Docker的标志就是鲸鱼上背着集装箱。
Docker历史
- 2010年,几个搞IT的年轻人,就在美国成立了一家公司dotcloud做一些pass的云计算服务,就是一个关于Linux服务器有关的容器技术,他们将自己的技术(容器化技术)命名为Docker。
- Docker刚诞生时没有让行业很关注,所以Docker就是不赚钱了,怎么办,要饿死了嘛,no no,创始人就决定将他开源(2013年),源代码公开出去。
- 哪曾想,果然免费的最好用啊,越来越多人发现Docker的优点,火了!问:怎么算火?答:每个月都有版本更新。
- Docker1.0发布(2014年4月9日)。
- 问:为什么这么火。答:很轻巧。问:具体说说。答:别急,继续往下看。
二、Docker为什么会出现
模拟场景一:产品软件研发——windows开发服务器(Ubuntu/CentOs)上线
运维:小李过来,你这写的什么软件,怎么运行不了。
程序员小李:什么!我在我的电脑上明明可以运行!!!
对于运维和开发人员来说,这就是典型的开发上线两套环境,研发人员写好后,上线的环境又要重新去配置,毕竟windows和linux还是有区别的。环境配置十分麻烦,每个机器都要部署环境(如集群Redis、ES、Hadoop等)真是费时费力,打工人大喊真实住了,狠狠共情。
那么问题来了:发布一个项目(jar+redis+MySQL+jdk+ES等等)能不能带上环境进行打包?
这不,Docker来了,新技术的出现就是有问题要解决。
对比与类比:
- 传统:
- 开发人员windows开发jar,运维来发布到Linux。
- java——apk——发布(应用商店)——张三使用apk包安装即可用。
- 有了Docker:
- 开发打包部署上线,一套流程全搞定。
- java——jar(环境)——打包项目带上环境(镜像)——(Docker仓库:商店)——下载发布的镜像直接运行。
模拟场景二:水果,肉类一起运输
问:一个船一起运输,串味怎么办?
答:使用集装箱,把水果放一个集装箱,肉类放一个,放在船上直接运走。
同样Docker就是一种集装箱技术,打包装箱,每个箱子都是互相隔离的,所以一个Docker容器出现问题也不要怕其他的容器会受到影响。
VMware为例
VMware大家应该很熟悉,虚拟机技术。我们经常在虚拟机装系统(如Ubuntu)每个镜像就是一个模仿真实操作系统,所以一个镜像就要一二十个G,多装几个的话,内存吃不消啊。而现在有了Docker,一个系统内可以装入多个容器,很小的空间也能压榨出来作为一个集装箱,甚至现在能装入十几个容器等。
- 虚拟机:在window中装一个Vmware,通过这个软件我们可以虚拟出来一台或者多台电脑!(很笨重)
- 虚拟机也是属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!
- vmware:隔离,需要开启多个虚拟机!linux centos原生镜像(一个电脑!)需要几个G内存空间,开启需要几分钟!
- docker:隔离,镜像(最核心的环境4m内存)十分的小巧,运行镜像就可以了!小巧!几个M或KB的内存空间,秒级启动!
三、Docker能做什么
讲到这里,大家应该了解了,我们做一下总结。
之前的虚拟机技术
- 资源占用十分多
- 冗余步骤多
- 启动很慢!
容器化技术
- 容器化技术不是模拟的一个完整的操作系统
- 比较Docker和虚拟机技术的不同:
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。
- 容器内的应用直接运行在宿主机的内核中,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了。
- 每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统,互不影响。
开发和运维
- 应用更快速的交付和部署
- 传统:一堆帮助文档,安装程序!
- Docker:打包镜像发布测试,一键运行!
- 更便捷的升级和扩缩容
- 使用了Docker之后,我们部署应用就和搭积木一样!
- 项目打包为一个镜像,扩展服务器A!服务器B!
- 更简单的系统运维
- 在容器化之后,我们的开发,测试环境都是高度一致的。
- 更高效的计算资源利用
- Docker是内核级别的虚拟化,可以在一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致。
总结
以上就是对Docker的概述。