若是你是数据中心或云计算IT圈子的人,这一年多来应该一直在听到普通的容器、尤为是Docker,关于它们的新闻从未间断过。Docker1.0在今年6月发布后,声势更是达到了史无前例的程度。web
动静之因此这么大,就是由于许多公司在以惊人的速度采用Docker。在今年7月的开源大会(OSCon)上,我遇到了早已将服务器应用程序从虚拟机(VM)转移到容器的无数企业。的确,Docker公司主管服务和支持的副总裁James Turnbull在会上告诉我,其中有三家大银行一直在使用Docker的测试版,现已在生产环境中使用Docker。对任何早期技术来讲,这无疑是极大的充满自信的举动,要知道它在安全至上的金融界几乎闻所未闻。docker
与此同时,Docker这项开源技术不只仅是红帽和Canonical等Linux巨头眼里的宠儿。微软等专有软件公司也在热烈拥抱Docker。安全
那么,为何你们都追捧容器和Docker呢?James Bottomley是Parallels公司的服务器虚拟化首席技术官,也是一位知名的Linux内核开发人员。他向我解释,Hyper-V、KVM和Xen等虚拟机管理程序都“基于虚拟化硬件仿真机制。这意味着,它们对系统要求很高。”服务器
然而,容器却使用共享的操做系统。这意味着它们在使用系统资源方面比虚拟机管理程序要高效得多。容器不是对硬件进行虚拟化处理,而是驻留在单单一个Linux实例上。这反过来意味着,你能够“丢弃没有用的99.9%的虚拟机垃圾,剩下一个小巧简洁的胶囊式容器,里面含有你的应用程序,”Bottomley如是说。网络
据Bottomley声称,所以,借助通过全面调优的容器系统,你就能够在同一硬件上拥有数量比使用Xen虚拟机或KVM虚拟机多出四到六倍的服务器应用实例。架构
是否是以为听起来很不错?毕竟,你可让服务器运行多得多的应用程序。那么,为何以前没有人作过呢?实际上,以前有人作过。容器实际上是个旧概念。分布式
容器能够追溯到至少2000年和FreeBSD Jails。甲骨文Solaris也有一个相似概念,名为Zones;Parallels、谷歌和Docker等公司一直在致力于研发诸如OpenVZ和LXC(Linux容器)之类的开源项目,旨在让容器运行起来顺畅又安全。ide
的确,不多有人知道容器,但大多数人多年来一直在使用容器。谷歌就有本身的开源容器技术lmctfy(Let Me Contain That For You,意为“让我容纳你的程序”)。只要你使用谷歌的某项功能:好比搜索、Gmail、Google Docks或不管其余什么,就分配了一个新的容器。微服务
然而,Docker创建在LXC的基础上。与任何容器技术同样,就该程序而言,它有本身的文件系统、存储系统、处理器和内存等部件。容器与虚拟机之间的区别主要在于,虚拟机管理程序对整个设备进行抽象处理,而容器只是对操做系统内核进行抽象处理。工具
这反过来意味着:虚拟机管理程序能作容器作不了的一件事就是,使用不一样的操做系统或内核。因此,举例说,你可使用微软Azure,同时运行Windows Server2012的实例和SUSE Linux企业级服务器的实例。至于Docker,全部容器都必须使用一样的操做系统和内核。
另外一方面,若是你只是想让尽量多的服务器应用实例在尽量少的硬件上运行,可能不大关心运行多个操做系统虚拟机。要是同一应用程序的多个副本正是你须要的,那么你会喜欢上容器。
改用Docker这一举措有望每一年为数据中心或云计算服务提供商节省数千万美圆的电力和硬件成本。因此难怪它们在一窝蜂地尽快采用Docker。
Docker带来了以前技术所没有的几个新特色。第一是,与以前的方法相比,Docker让容器部署和使用起来更容易、更安全。此外,因为Docker与其余容器领域的巨擘进行了合做,包括Canonical、谷歌、红帽和Parallels,共同开发其关键的开源组件libcontainer,它为容器带来了迫切须要的标准化。
与此同时,广大开发人员可使用Docker封装、交付和运行任何应用程序,应用程序成为轻型的、可移植的、自给自足的LXC容器,能够在任何地方运行。正如Bottomley告诉我,“容器让你当即享有应用程序可移植性。”
市场研究公司451 Research的资深分析师Jay Lyman补充道:“企业组织力求以一种高效、标准化、可重复的方式,让应用程序和工做负载更易于移植和分发,而有时很难作到这点。正如GitHub经过共享源代码来促进合做和创新那样,Docker Hub、Official Repos和商业支持也在帮助众多企业经过改进封装、部署和管理应用程序的方式,应对这个难题。”
最后但并不是最不重要的,Docker容器易于部署到云端。正如Ben Lloyd Pearson在opensource.com上写道:“Docker采用了一种特别的方式,以即可以整合到大多数DevOps(开发运营)应用程序当中,包括Puppet、Chef、Vagrant和Ansible,或者能够独自使用,以管理开发环境。主要卖点是,它简化了一般由另外这些应用程序执行的好多任务。具体来讲,有了Docker,人们就能够搭建与活动服务器如出一辙的本地开发环境,从同一个主机运行多个开发环境(每一个开发环境有独特的软件、操做系统和配置),在新的或不一样的服务器上测试项目,以及让任何人均可以在设置如出一辙的状况下处理同一项目,不管本地主机环境怎样。”
简而言之,Docker能为你作的事情就是:相比其余技术,它能让更多数量的应用程序在同一硬件上运行;它让开发人员易于快速构建可随时运行的容器化应用程序;它大大简化了管理和部署应用程序的任务。总而言之,我能理解做为一项企业级技术,Docker为什么一会儿蹿红。我只是但愿它不负众望,不然外头会有一些忧心忡忡的CEO和CIO。
diff
命令。