一款产品从开发到上线,从操作系统,到运行环境,再到应用配置。作为开发+运维之间的协作,我们需要关心很多东西,这也是很多互联网公司都不得不面对的问题,特别是各种版本的迭代之后,不同版本环境的兼容,对运维人员都是考验。环境配置如此麻烦,换一台机器,就要重来一次,费时费力。很多人就在想,能不能从根本上解决问题,软件可以带环境安装?也就是说,安装的时候,把原始环境一摸一样的复制过来。开发人员利用docker可以消除协作编码时“在我电脑上是正常的呀”的问题。
Docker之所以发展如此迅速,也是因为它对此给出了一个标准化的解决方案
之前在服务器配置一个应用的运行环境,要安装各种软件,比如,java/tomcat/mysql/jdbc驱动包等等,还有各种中间件mqtt,zookeeper等等,安装和配置这些东西有多麻烦就不说了,它还不能跨平台。假如我们是在windows上安装的这些环境,到了linux又得重新安装。况且就算不跨操作系统,换另一台同样操作系统的服务器,要移植应用也是非常麻烦,相当于又要重复的部署。几台服务器还好说,万一哪天领导安排一项任务,运维的同事要在40台服务器上部署应用,每一台都重新配置搞环境,岂不是忙不过来;假设,有一套已配置好的全家桶,直接放在每一台服务器上就可以跑起来正常使用,那就方便多了。传统上认为,软件编码开发并测试结束后,所产出的成果即程序。而为了让这些程序可以顺利执行,开发团队也得准备完整的部署文件,让运维团队得以部署应用程序。开发需要清楚的告诉运维部署团队,用的全部的配置文件+所有软件环境。不过即便如此,也仍然常常发生部署失败的状况。Docker镜像的设计,使得docker打破过去的旧观念。透过镜像(images)将作业系统核心除外,运作应用程序所需要的系统环境,由下而上打包,达到应用程序跨平台间的无缝接轨运作
一、docker的基本概念
1.1docker是什么?
①Docker是基于Go语言实现的云开源项目
②Docker的主要目标是“Build,ShipandRunAnyApp,Anywhere”,构建、安装、运行任何应用在任何平台;也就是通过对应用组建的封装、分发、部署、运行等生命周期的管理,使用户的APP及其运行环境能够做到“一次封装,到处运行”
③Linux容器技术的出现就解决了这样的一个问题,而docker就是在它的基础上发展过来的,将应用运行在docker容器上面,而docker容器在任何操作系统上都是一致的,这就实现了跨平台、跨服务器。只需要一次配置好环境,换到别的机子上就可以一键部署,大大简化了操作
一句话:解决了运行环境和配置问题软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术
1.2docker能干什么?
①Docker和传统虚拟化方式的不同之处
*传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程
*而容器内的应用进程直接运行于宿主机的内核,容器内没有自己的内核,而且也没有进行硬件虚拟,因为,容器要比传统虚拟机更为轻便
*每个容器之间互相隔离,每个容器都有自己的文件系统,容器之间进程不会互相影响,能区分计算资源
②传统虚拟机的缺点:
资源占用多,冗余步骤多,启动慢
③Docker的优势:
·轻量、秒级的快速启动速度
· 简单,易用
· 标准统一的打包/部署/运行方案
· 镜像支持增量分发,易于部署
· 易于构建,适合自动化测试和持续集成
1.3docker去哪里下载?
docker官网:http://www.docker.com
Docker中文网站:https://www.docker-cn.com/
自学的话,下一个社区版就可以,免费使用就行
1.4docker的三要素:镜像、容器、仓库
镜像、容器、仓库,怎么来理解这三个概念?
①镜像就是一个只读的模板,镜像可以用来创建docker容器,一个镜像可以创建很多个容器
②容器是镜像创建出来的实例,它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。可以把容器看作是一个简易版的Linux环境
③仓库是集中存放镜像文件的场所;仓库和仓库注册服务器是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签,
仓库分为公开仓库和私有仓库两种形式,最大的公开仓库是https://hub.docker.com/,里面存放着数量庞大的镜像供用户下载。国内的公开仓库包括阿里云,网易云等等。
---------需要正确理解以上三个要素的概念----------:
Docker本身就是一个容器运行载体或者称之为管理引擎。我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就似乎image镜像文件,只有通过这个镜像文件才能生成Docker容器,image文件可以看作是容器的模板,docker根据image文件生成容器的实例同一个image文件,可以生产多个同时运行的容器实例。
*image文件生成的容器实例,本身也是一个文件,成为镜像文件
*一个容器运行一种服务,当我们需要的时候,就可以通过docker客户创建一个对应的运行实例,也就是我们的容器
*至于仓储,就是放了一堆镜像的地方,我们可以把镜像发布到仓储中,需要的时候,从仓储中拉下来就可以了。
作者:excellent_1