Docker的核心是什么?

allowtransparency="true" frameborder="0" scrolling="no" src="http://hits.sinajs.cn/A1/weiboshare.html?url=http%3A%2F%2Fwww.csdn.net%2Farticle%2F2015-04-30%2F2824593&type=3&count=&appkey=&title=%E4%B8%8D%E4%B9%85%E5%89%8DDocker%E5%88%9A%E5%88%9A%E5%AE%8C%E6%88%90%E4%BA%869500%E4%B8%87%E7%BE%8E%E5%85%83%E7%9A%84%E6%96%B0%E4%B8%80%E8%BD%AE%E6%8A%95%E8%B5%84%EF%BC%8C%E5%B8%82%E5%9C%BA%E4%BC%B0%E5%80%BC%E5%B7%B2%E7%BB%8F%E8%BE%BE%E5%88%B010%E4%BA%BF%E7%BE%8E%E9%87%91%EF%BC%8C%E8%80%8C%E5%88%B0%E7%9B%AE%E5%89%8D%E4%B8%BA%E6%AD%A2Docker%E8%BF%98%E6%B2%A1%E6%9C%89%E7%9C%9F%E6%AD%A3%E7%9A%84%E5%95%86%E4%B8%9A%E4%BA%A7%E5%93%81%EF%BC%8C%E9%82%A3%E4%B9%88%E4%B8%BA%E4%BB%80%E4%B9%88Docker%E8%BF%99%E4%B9%88%E7%81%AB%E5%91%A2%EF%BC%9F%E9%92%88%E5%AF%B9%E8%BF%99%E4%B8%AA%E9%97%AE%E9%A2%98%EF%BC%8CDVM%E5%88%9B%E5%A7%8B%E4%BA%BA%E5%85%BCCTO%E7%8E%8B%E6%97%AD%E7%BB%99%E5%87%BA%E4%BA%86%E4%B8%93%E4%B8%9A%E7%9A%84%E8%A7%A3%E7%AD%94%E3%80%82&pic=&ralateUid=&language=zh_cn&rnd=1430393739572" width="22" height="16"> 摘要:不久前Docker刚刚完成了9500万美元的新一轮投资,市场估值已经达到10亿美金,而到目前为止Docker还没有真正的商业产品,那么为什么Docker这么火呢?针对这个问题,DVM创始人兼CTO王旭给出了专业的解答。

在基础技术创业这个圈子里,Docker算是最火的独角兽了。不久前Docker刚刚完成了9500万美元的新一轮投资。要知道Docker是个纯开源,完全底层Building Block的技术,而且到目前为止Docker还没有真正的商业产品。

那么, 究竟什么让Docker这么火呢?

大家都知道:

Docker = LXC + AUFS

从一方面看,Docker从诞生至今都定位于Container之上,那么Docker的核心是Container么?而从另一方面,Docker在标准的LXC之上又融合AUFS这样的分层镜像管理机制,那么AUFS是Docker的核心?

话还是从我们的DVM项目说起吧。DVM是一个混合了Hypervisor(虚拟化)和Docker的开源项目。你可以使用DVM在物理机上启动任何Docker镜像。不同之处是,DVM没有使用LXC,而是使用了Hypervisor (KVM, Xen, ESX),创建了一个VM来运行Docker镜像。

乍听起来,DVM有点像基于VM运行的CoreOS或者RancherOS。但实际上,DVM的虚机内部不是一个完整操作系统(CoreOS虽然精简,但仍然是个完整的OS)。DVM的虚机内部只有一个Linux Kernel。而这个kernel会从物理机的硬盘上加载并运行Docker镜像。更重要的是:DVM创建VM的时候,由于这个kernel能在毫秒级完成启动,所以使用DVM启动Docker镜像的耗时跟LXC相差无几。

而从运行性能看,虚拟化的性能虽然有一定损失,但差距并不是太大:

  • CPU性能相比物理机只有0.5-2%的损失
  • 内存消耗比LXC多10MB
  • 磁盘和网络性能,在云环境下由于SDN和分布式存储的原因,DVM也和LXC非常接近

既然DVM可以使用虚拟机直接启动Docker镜像,而且性能接近Container,那么Container就不是Docker运行的唯一选择,因此也就不是Docker的核心。

再来看AUFS,第一次看到Docker的时候,大家都被它类似于Git的镜像管理流程吸引。不过仔细想想,这个功能更多的被用来实现增量部署更新。而从"集装箱化"这个角度,AUFS并没有直接的关系。作为例子,CoreOS的Rocket并未采用类似的分层文件系统技术。另一方面,传统虚拟机镜像也能结合AUFS达到类似的效果。那么为什么虚拟化厂商之前没有想到类似Docker的idea呢?

原因很简单,Docker的真正核心在于:

它抛弃传统VM试图模拟完整机器的思路,而是以应用为单元进行"集装封箱"

这样做的好处主要有两个:

  1. 加快启动速度:我们知道,为了兼容性,通用性的考虑,虚拟化厂商无法对OS进行优化。传统VM启动之所以慢,很大程度是因为OS启动耗时。反观Docker,由于只考虑应用本身,当Docker镜像启动时就可以做到心无杂念,自然也就快。
  2. 精简镜像:从技术角度来说,AUFS也可以应用在VM的镜像(qcow2)。但由于VM面向的是完整的OS,其中包含了各种服务,导致VM镜像一般体积较大(GB),不方便交付和部署。而Docker不关心完整的OS,只包含应用运行所需的最小集合,因此镜像体积只有200-300MB,大大缩短了镜像的下载时间。

说到这里,你可以看到"面向应用"是Docker最核心的理念。那自然而然的问题是:

既然Docker已经证明我们不需要完整的OS,那我们是否还需要一个完整的Kernel?

在DVM项目里,我们开发了一个HyperKernel, 它非常精简,资源占用极低,不过它仍然是个通用的Linux内核,仍然存在大量的简化,重构的空间。我们可不可以大胆想象,HyperKernel在未来会不会进化为一个专用的,极简的内核?

于是,我们成立了一家startup,而在5.1之后DVM也即将开源。我们希望能推动Kernel,Hypervisor,Docker技术的发展,并打造新一代Kernel Distro,也很期待有一样理想的“内核er”们的加入!

作者简介

王旭:DVM创始人,CTO,前VisualOps CTO,多年的Debian,Kernel,分布式存储老兵

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值