Docker对我们大多数人来说并不是一个新词, 它无处不在。 但究竟Docker是什么?
很简单,Docker是一个软件集装箱化平台,这意味着您可以构建应用程序,将它与其依赖关系一起打包到一个容器中,然后这些容器可以很容易地运送到其他机器上运行。
好的,但什么是集装箱?
集装化(也称为基于容器的虚拟化和应用程序集装箱化)是用于部署和运行分布式应用程序的OS级虚拟化方法,无需为每个应用程序启动整个VM。 相反,多个独立的系统(称为容器)在单个控制主机上运行并访问单个内核。
容器映像是一个轻量级的、独立的、可执行的软件包,它包括运行它所需的一切:代码、运行时、系统工具、系统库设置。
所以主要目标是将软件打包成标准化的单元进行开发,发货和部署。
例如,假设有一个用Scala和R编写的Linux应用程序。因此,为了避免Linux,Scala和R发生任何版本冲突,Docker只会将此应用程序包装在具有所有版本和依赖项的容器中,并部署 它在任何操作系统或服务器上都没有任何版本麻烦。
现在,我们需要做的就是运行这个容器,而不用担心依赖的软件和库。
所以,这个过程非常简单。 每个应用程序将在单独的容器上运行,并将拥有自己的一组库和依赖项。 这也确保了进程级别的隔离,这意味着每个应用程序独立于其他应用程序,从而使开发人员可以确保他们可以构建不会相互干扰的应用程序。
容器vs.虚拟机
容器是应用程序层的抽象,它将代码和依赖关系打包在一起。 多个容器可以在同一台计算机上运行,并与其他容器共享操作系统内核,每个容器都作为用户空间中的独立进程运行。 容器占用的空间少于虚拟机(容器图像的大小通常为几十MB)并且几乎立即启动。
正如您在集装箱中看到的那样,有一个主机操作系统,然后在上面将会有容器具有每个应用程序的依赖关系和库,这使得处理和执行速度非常快。 这里没有客户操作系统,它利用主机的操作系统,与虚拟机不同,在需要时共享相关的库和资源。
虚拟机(VMs)是将一台服务器变成多台服务器的物理硬件的抽象。 管理程序允许多台虚拟机在单台机器上运行。 每个VM都包含一个操作系统的完整副本,一个或多个应用程序,必需的二进制文件和占用数十GB的库。 VM也可能启动缓慢。
在这种虚拟化的情况下,有一个主机操作系统,其中有3个客户操作系统在运行,它们只不过是虚拟机。 但是,在同一主机操作系统上运行多个虚拟机会导致性能下降,因为每个虚拟机都有自己的内核和一组库以及依赖关系。 这占用了大量的系统资源,如硬盘,处理器,特别是RAM。
所以,这是对Docker,集装箱化和虚拟化的简要概述。
更多阅读
课课家教育_大数据hadoop基础篇1-HDFS文件系统视频教程
什么是云计算?_课课家教育
2018年度云技术对小企业的5项效益
领取专属 10元无门槛券
私享最新 技术干货