Docker Compose 是 Docker 官方开源的容器编排(Orchestration)项目之一,用于快速部署分布式应用。本文将介绍 Docker Compose 的基本概念、安装流程及使用方法。
简介
Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排。从功能上看,Docker Compose 和 OpenStack 中的 Heat 十分类似。
我们知道,使用 Dockerfile 模板文件可以让用户很方便的定义一个单独的应用容器。然而,在实践过程中,我们经常会遇到需要多个容器相互配合来完成某项任务的情况。例如要实现一个 Web 项目,除了 Web 服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。Compose 就是为了满足这样的需求而出现的。
Docker Compose 允许用户通过一个单独的 docker-compose.yml
模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。这里有两个重要的概念 —— 服务和项目。
- 服务(service):是指一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
- 项目(project):是指由一组关联的应用容器组成的一个完整业务单元,在
docker-compose.yml
文件中定义。
其中,项目是 Compose 默认的管理对象,可通过子命令对项目中的一组容器进行生命周期管理。
Compose 项目最早由 Python 编写,实现上调用了 Docker 服务提供的 API 来对容器进行管理。因此,只要所操作的平台支持 Docker API,就可以在其上利用 Compose 来进行编排管理。
后来 Docker 官方用 Go 语言重写了 Docker Compose,称为
Compose V2
。并将其作为了 docker cli 的子命令,所以 V1 和 V2 版本的命令有一些区别(你需要将docker-compose
命令替换为docker compose
)。
安装
如果你在 Windows 或 Mac 上使用 Docker Desktop,则已经包含了 docker-compose,可以直接使用。如果你使用的是 Linux,则需要单独安装。下面以 Ubuntu 20.04 为例,介绍如何在 Linux 系统中安装 docker-compose。
首先,在 Compose 仓库的 releases 页面 下载你的目标平台最新的 docker-compose 软件包,我们这里下载的是 docker-compose-linux-x86_64
。
然后,将其复制/移动到系统安装目录(例如 /usr/local/bin
):
$ sudo mv ~/Downloads/docker-compose-linux-x86_64 /usr/local/bin/docker-compose
写这篇文章时最新的版本是 2.26.1
,你可以通过下面命令一键下载并将其安装到系统目录:
$ sudo curl -L "https://github.com/docker/compose/releases/download/v2.26.1/docker-compose-linux-$(uname -m)" -o /usr/local/bin/docker-compose
接着,你需要给 docker-compose
添加可执行权限,命令如下:
$ sudo chmod +x /usr/local/bin/docker-compose
完成后可通过 docker-compose --version
检查其版本信息,确认安装是否成功。
$ docker-compose --version
Docker Compose version v2.26.1
这样,docker-compose 就已经安装好了!
使用
下面通过一个实例来演示