基于Go语言进行开发实现,基于Linux内核的cgroup、namespace以及AUFS类的Union FS等技术,对进程进行封装隔离,属于操做系统层面的虚拟化技术。因为隔离的进程独立于宿主和其余进程隔离的进程,所以也称为容器。服务器
1.更高效的利用系统资源测试
容器无需进行硬件虚拟以及运行完整操做系统等额外开销,Docker对系统资源的利用率更高。应用执行速度、内存损耗或者文件存储速度,都要比传统虚拟机技术更高效。spa
2.更快速的启动时间操作系统
Docker直接运行于宿主内核,无需启动完整的操做系统,能够作到秒级、甚至毫秒级的启动时间,大大节约开发、测试、部署的时间。进程
3.一致的运行环境内存
Docker提供了除内核外完整的运行时环境,确保了运行环境一致性。资源
4.持续交付和部署开发
使用Docker能够经过定制应用镜像来实现持续集成、持续交付、部署。部署
5.更轻松的迁移虚拟机
Docker确保了执行环境的一致性,使得应用的迁移更加容易。
6.更轻松的维护和扩展
使用的分层存储以及镜像技术,使得应用重复部分的复用更加容易,也使得应用的维护更新更加简单,基于基础镜像进一步扩展镜像也变得很是简单。此外,还有开源项目团队维护的官方镜像,大大下降了应用服务的镜像制做成本。
对比总结
镜像至关于一个root文件系统,做为一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些运行时准备的一些配置参数。镜像不包含任何动态数据,其内容在构建以后也不会被改变。
镜像是虚拟概念,其实际体现并不是由一个文件组成,而是由一组文件系统组成,或者说由多层文件系统联合组成。镜像分层存储,分层构建,前一层是后一层的基础,这使得镜像的复用、定制变得容易。
镜像与容器的关系,相似于类和实例。镜像是静态的定义,容器是镜像运行时的实体。
容器的实质是进程,但与直接在宿主执行的进程不一样,容器进程运行于属于本身的独立的命名空间。
镜像构建完成后,若是须要在其余服务器上使用这个镜像,咱们就须要一个集中的存储、分发镜像的服务,Docker Registry就是这样的服务。
<仓库名>:<标签>标签经常使用于对应该软件的各个版本。