docker简介
首先介绍一下容器与虚拟化的区别
VM(VMware)在宿主机器、宿主机器操作系统的基础上创建虚拟层、虚拟化的操作系统、虚拟化的仓库,然后再安装应用;
Docker在宿主机器的操作系统上创建Docker引擎,直接在宿主主机的操作系统上调用硬件资源,而不是虚拟化操作系统和硬件资源,所以操作速度快。
docker是一个用Go语言实现的开源项目,可以让我们方便的创建和使用容器,docker将程序以及程序所有的依赖都打包到docker container,这样你的程序可以在任何环境都会有一致的表现,这里程序运行的依赖也就是容器就好比集装箱,容器所处的操作系统环境就好比货船或港口,程序的表现只和集装箱有关系(容器),和集装箱放在哪个货船或者哪个港口(操作系统)没有关系。
因此我们可以看到docker可以屏蔽环境差异,也就是说,只要你的程序打包到了docker中,那么无论运行在什么环境下程序的行为都是一致的。
此外docker的另一个好处就是快速部署,这是当前互联网公司最常见的一个应用场景,一个原因在于容器启动速度非常快,另一个原因在于只要确保一个容器中的程序正确运行,那么你就能确信无论在生产环境部署多少都能正确运行。
docker产生的背景
一款软件或服务产生的原因和背景有一定的原因是为了解决生产或工作环境中遇到的问题
-
生产、工作中产生的问题开发和运维环境或配置不同,导致开发环境运行良好的交付产物在运维环境出问题,此类问题让人不胜其烦。
-
传统运维过程中,如果线上有十台机器,每台都需要重新部署一次,重复劳动。
-
配置应用环境不能跨平台。
-
多个应用安装到环境中可能会冲突,例如端口冲突。
传统的发布流程:
软件包->发布(应用商店)->下载包->安装可用
docker发布流程:
软件包->打包带上环境(镜像)->Docker仓库:商店->下载发布的镜像->直接运行可用
docker的机制很好的解决了这些问题
1,docker源于集装箱的思想,自带隔离机制,容器与容器之间互不干扰
2,一次构建,随处运行。docker可以将写好镜像文件进行打包到任何docker服务中去运 行,这个源于docker的容器格式:Docker引擎将名称空间、控制组和联合文件系统打包 到一起所使用的就是容器格式。默认的容器格式是Libcontaine
3,docker的控制组和联合文件系统,可以设置进程的cpu内存等使用限额,而联合文件系统可以建立联合挂载点,共享存储。
什么是LXC
通过传统方式使用容器功能的话需要我们自己写代码去进行系统调用来实现创建内核,实际上拥有此能力的人廖廖无几。而LXC(LinuX Container)把容器技