Docker为什么出现?
一款产品:开发—上线 两套环境! 应用环境,应用配置!
开发 —- 运维. 为题:在我的电脑上可以运行!版本更新,导致服务不可用!对运维来说,考验十分大?
传统开发流程: 开发 ,运维部署
现在: 开发打包部署上线,一套流程完成
打包项目带上环境(镜像) — (Docker仓库) — 下载我们发布的镜像—直接运行即可
Docker 给以上的问题提出了解决方案!
Docker的思想来源于集装箱!
多个应用(端口冲突) — 原来都是交叉的!
隔离: docker核心思想! 打包装箱!每个箱子互相隔离的.
Docker通过隔离机制,可以将服务器利用到极致!
本质:所有的技术都是因为出现了一些问题,我们需要去解决才去学习!
Docker历史
2010年,几个搞IT的年轻人,在美国成立了一家公司dotCloud
做一些 pass 的云计算服务 , LXC有关的容器技术!
他们将自己的技术(容器化技术)命名就是Docker !
Docker 刚刚诞生的时候,没有引起行业的注意! dotCloud,活不下去了
开源 **开放源代码
2013年 , Docker开源!
Docker越来越多的人发现docker的优点!火了,Docker每个月都会更新一个版本!
2014年4月9日,Docker**1.0发布!
Docker为什么这么火? 十分轻巧!
在容器技术出来之前,我们都是使用虚拟机技术! 笨重!
虚拟机也是虚拟化技术,Docker容器技术,也是一种虚拟化技术!
VM : Linux centos 原生镜像(一个电脑) 隔离,需要开启一个虚拟机! 几个G 几分钟
Docker : 隔离,镜像 十分的小巧,运行镜像就可以了! 小巧! 几个M kb 秒级启动!
到现在 ,docker是开发人员必备的
比较Docker 和 虚拟技术的不同
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后运行在这个系统上安装和运行软件
- 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
- 每个肉器是相互隔离,每个容器都有属于自己的文件系统,互不影响
DevOps(开发 运维)
应用更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用了Docker之后,我们部署应用就和搭积木一样!
更简单的系统运维
在容器化之后,我们的开发,测试环境都高度一致的
更高效的计算资源利用
Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例,服务器性能可以被压榨到极致.
