一、概述
1.1 基本概念:
docker 是一个开源的应用容器引擎,基于 go 语言 并遵从apache2.0协议开源。docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iphone 的 app),更重要的是容器性能开销极低。
1.2 优势:
简化程序:
docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 linux 机器上,便可以实现虚拟化。docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入docker中进行管理。方便快捷已经是 docker的最大优势,过去需要用数天乃至数周的任务,在docker容器的处理下,只需要数秒就能完成。
节省开支:
一方面,云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,docker 改变了高性能必然高价格的思维定势。docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式。
1.3 与传统vm特性对比:
作为一种轻量级的虚拟化方式,docker在运行应用上跟传统的虚拟机方式相比具有显著优势:
docker容器很快,启动和停止可以在秒级实现,这相比传统的虚拟机方式要快得多。
docker容器对系统资源需求很少,一台主机上可以同时运行数千个docker容器。
docker通过类似git的操作来方便用户获取、分发和更新应用镜像,指令简明,学习成本较低。
docker通过dockerfile配置文件来支持灵活的自动化创建和部署机制,提高工作效率。
docker容器除了运行其中的应用之外,基本不消耗额外的系统资源,保证应用性能的同时,尽量减小系统开销。
docker利用linux系统上的多种防护机制实现了严格可靠的隔离。从1.3版本开始,docker引入了安全选项和镜像签名机制,极大地提高了使用docker的安全性。
特性
容器
虚拟机
启动速度
秒级
分钟级
硬盘使用
一般为mb
一般为gb
性能
接近原生
弱于原生
系统支持量
单机支持上千个容器
一般几十个
隔离性
安全隔离
完全隔离
1.4 基础架构
docker 使用客户端-服务器 (c/s) 架构模式,使用远程api来管理和创建docker容器。
docker 容器通过 docker 镜像来创建。
容器与镜像的关系类似于面向对象编程中的对象与类。
docker
面向对象