Docker为什么出现?
- 环境配置是十分的麻烦,每个机器都要部署环境(集群Redis、ES、Hadoop......);
- 发布一个项目(jar+(Redis MySQL jdk ES),项目能不能带着环境安装打包;
- 在服务器配置应用的一个环境Redis MySQL jdk ES Hadoop,配置很麻烦,不能跨平台;
- Windows开发,发布到Linux;
- 传统:开发jar ,运维来做;
- 现在:开发打包部署上线,一套流程做完;
Docker对以上问题,提出了解决方案
Docker的思想来自与集装箱;
JRE -- 多个应用(端口冲突) -- 原来都是交叉的
隔离:Docker的核心思想就是打包装箱,每个箱子是相互隔离的。
Docker通过隔离机制,可以将服务器利用到机制;
Docker的历史
2010年,几个搞IT的年轻人,在美国成立了一家公司dotCloud
做—些PaaS的云计算服务!LXC有关的容器技术
他们将自己的技术(容器化技术)命名就是Docker!
Docker刚诞生的时候,没有引起行业的注意!dotCloud就活不下去
开源
开发源代码!
2013年,Docker开源!
Docker越来越多的人发现了docker的优点!火了,Docker每个月都会更新一个版本!
2014年4月9日,Docker1.0发布!
Docker为什么这么火?十分的轻巧!
在容器技术出来之前,我们都是使用虚拟机技术!
虚拟机:在windows中装一个Vmware,通过这个软件我们可以虚拟出来一台或者多台电脑!笨重!
虚拟机属于虚拟化技术,Docker容器技术也是一种虚拟化技术!
官网:https://www.docker.com/
仓库地址:https://hub.docker.com/
Docker文档位置,文档地址:https://docs.docker.com/
Docker能干嘛
虚拟机技术:
虚拟机技术缺点
1、资源占用十分多
2、冗余步骤多
3、启动很慢!
容器技术:
容器技术不是模拟一个完整的操作系统!
容器与虚拟机不同点
虚拟机:
- 虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件;
容器:
- 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了;
- 每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统,互不影响。
- 应用更快速的交付和部暑
- 传统:一堆帮助文档,安装程序
- Docker:打包臆像发布测试,一键运行
4. 更便捷的升级和扩缩容
- 使用了Docker之后,我们部署应用就和搭积木一样!
- 项目打包为一个镜像,扩展服务器A、服务器B
5. 更简单的系统运维
- 在容器化之后,我们的开发,测试环境都是高度一致的。
6. 更高效的计算资源利用
- Docker是内核级别的虚拟化,可以再一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致。