Docker与传统虚拟机的区别
Docker 和传统虚拟化方式的不同之处。传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程;而容器内的应用进程直接运行于宿主的内核,容器内没有自己的内核,而且也没有进行硬件虚拟。因此容器要比传统虚拟机更为轻便。
- 应用
- 应用依赖的环境(库等)
-
guest OS 虚拟机
- Docker Engine docker引擎 | Hypervisor 虚拟层(VM软件)
- Host OS 宿主操作系统
- server 硬件
Docker容器技术–》应用容器技术(容器里面运行软件环境)
为什么是Docker
为什么要选择docker呢,我们直接部署好环境,开发完不就好了,为什么还要多加一步docker呢?这看起来是更麻烦了,但却避免了很多麻烦!
-
在开发的时候,在本机测试环境可以跑,生产环境跑不起来
这里我们拿java Web应用程序举例,我们一个java Web应用程序涉及很多东西,比如jdk、tomcat、mysql等软件环境。当这些其中某一项版本不一致的时候,可能就会导致应用程序跑不起来这种情况。Docker则将程序以及使用软件环境直接打包在一起,无论在那个机器上保证了环境一致。
优势1: 一致的运行环境,更轻松的迁移
-
服务器自己的程序挂了,结果发现是别人程序出了问题把内存吃完了,自己程序因为内存不够就挂了
这种也是一种比较常见的情况,如果你的程序重要性不是特别高的话,公司基本上不可能让你的程序独享一台服务器的,这时候你的服务器就会跟公司其他人的程序共享一台服务器,所以不可避免地就会受到其他程序的干扰,导致自己的程序出现问题。Docker就很好解决了环境隔离的问题,别人程序不会影响到自己的程序。
优势2:对进程进行封装隔离,容器与容器之间互不影响,更高效的利用系统资源(操作系统级别的进程的封装隔离)
-
公司要弄一个活动,可能会有大量的流量进来,公司需要再多部署几十台服务器
在没有Docker的情况下,要在几天内部署几十台服务器,这对运维来说是一件非常折磨人的事,而且每台服务器的环境还不一定一样,就会出现各种问题,最后部署地头皮发麻。用Docker的话,我只需要将程序打包到镜像,你要多少台服务,我就给力跑多少容器,极大地提高了部署效率。
优势3: 通过镜像复制N多个环境一致容器
镜像(Images)
- 将应用与其环境打包在一起,其学名叫Images,一个镜像就代表一个软件:如mysql镜像 redis镜像 nginx镜像…,这些镜像需要运行起来,成为服务(容器)
- 镜像是可读的,不可修改
容器(container)
定义:基于某个镜像运行一次就是生成一个程序实例,其称之为一个容器,也称之为一个服务。容器与容器之间互不影响,相互隔离
- 容器是可读可写的
仓库(repository)
定义:用来存储docker中的所有镜像具体位置
远程仓库:docker在世界范围维护一个唯一远程仓库
本地仓库:当前自己机器中下载镜像存储位置