Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
Docker应用及场景,docker其实简单的来讲就是一个让我们创建一个开发环境的工具,比如我们的服务器很多需要安装很多的配置nginx,tomcat,jdk等等,而且每台服务器用的配置还有可能不一样而且配置一遍的时间非常长,docker的作用就是使这一切简单化,需要什么环境在docker里面创建一个就可以了不需要自己去一个一个的安装配置,而且能很大限度的保证开发环境的一致性,如果不需要这个环境或要一个更高的版本只需要把原来的删掉就可以了。
Docker并不是全能的,设计之初也不是KVM之类虚拟化手段的替代品,简单总结几点:Docker是基于Linux 64bit的,无法在32bit的linux/Windows/unix环境下使用,LXC是基于cgroup等linux kernel功能的,因此container的guest系统只能是linux base的,隔离性相比KVM之类的虚拟化方案还是有些欠缺,所有container公用一部分的运行库,网络管理相对简单,主要是基于namespace隔离,cgroup的cpu和cpuset提供的cpu功能相比KVM的等虚拟化方案相比难以度量(所以dotcloud主要是按内存收费),docker对disk的管理比较有限,container随着用户进程的停止而销毁,container中的log等用户数据不便收集