Docker是一个开发、运输和运行应用程序的开放平台。Docker可以将应用程序和软件应用环境分离,以便快速的交付软件。使用Docker,可以像管理软件那样管理运行环境,并能够利用Docker提供的功能来快速的发布、测试及部署代码,减少开发环境和部署环境配置不一致的问题。

简而言之:Docker是一种可以在同样硬件上实现不同环境的软件,解决了“这段代码在我的机器上没问题呀”的甩锅问题。

Docker简介

Docker 最初是 dotCloud 公司创始人 Solomon Hykes 在法国期间发起的一个公司内部项目,它是基于 dotCloud 公司多年云服务技术的一次革新,并于 2013 年 3 月以 Apache 2.0 授权协议开源,主要项目代码在 GitHub 上进行维护。Docker 项目后来还加入了 Linux 基金会,并成立推动 开放容器联盟(OCI)。


Docker 自开源后受到广泛的关注和讨论,甚至由于 Docker 项目的火爆,在 2013 年底,dotCloud 公司决定改名为 Docker。Docker 最初是在 Ubuntu 12.04 上开发实现的;Red Hat 则从 RHEL 6.5 开始对 Docker 进行支持;Google 也在其 PaaS 产品中广泛应用 Docker。


Docker 使用 Google 公司推出的 Go 语言 进行开发实现,基于 Linux 内核的 cgroup,namespace,以及 AUFS 类的 Union FS 等技术,对进程进行封装隔离,属于 操作系统层面的虚拟化技术。由于隔离的进程独立于宿主和其它的隔离的进程,因此也称其为容器。最初实现是基于 LXC,从 0.7 版本以后开始去除 LXC,转而使用自行开发的 libcontainer,从 1.11 开始,则进一步演进为使用 runC 和 containerd。


Docker 在容器的基础上,进行了进一步的封装,从文件系统、网络互联到进程隔离等等,极大的简化了容器的创建和维护。使得 Docker 技术比虚拟机技术更为轻便、快捷。

Docker引擎

Docker引擎是一个CS架构的应用程序,其中包括以下组件:

1. 服务器:一个长时间运行的程序,称为守护程序进程。

2. REST API:指定客户端程序和服务端程序进行交互的接口。

3. CLI:命令行界面客户端。

CLI使用Docker REST API通过脚本或者CLI命令控制Docker守护程序或者与Docker守护程序进行交互。


Docker架构

前面说过Docker是一个CS架构的应用程序。Docker客户端和Docker服务端进行通信,后者负责构建、运行和分发Docker容器。

Docker的客户端和服务端可以在同一台机器上运行,也可以将Docker客户端连接到远程Docker服务端。

Docker客户端和服务端通过REST API进行通信。

Docker服务端

Docker服务端(Docker守护进程)是用于接收Docker API请求并管理Docker对象,如镜像(images)、容器(containner)、网络(network)和数据卷(volumes)等。

Docker应用程序还可以与其他守护程序通信以管理Docker服务。


Docker客户端

Docker客户端是用户与Docker进行直接交互的地方,当使用如Docker run这些命令的时候,客户端会将这些命令发送到服务端进行执行。Docker客户端可以与多个守护进程进行通信。


Docker仓库

Docker仓库是一个可以存储Docker镜像的地方。Docker Hub是任何人都可以使用的公共仓库。Docker默认配置也是在Docker Hub上查找镜像。