11_compose/11.1_introduction.md
Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器的快速编排。从功能上看,跟 OpenStack 中的 Heat 十分类似。
其代码目前在 docker/compose 仓库 上开源。
Compose 定位是 “定义和运行多个 Docker 容器的应用 (Defining and running multi-container Docker applications)”,其前身是开源项目 Fig。
通过第一部分中的介绍,我们知道使用一个 Dockerfile 模板文件,可以让用户很方便的定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个 Web 项目,除了 Web 服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
Compose 恰好满足了这样的需求。它允许用户通过一个单独的 compose.yaml (历史默认名也常见为 docker-compose.yml) 模板文件 (YAML 格式) 来定义一组相关联的应用容器为一个项目 (project)。
Docker Compose 让用户能够以声明式方式定义和管理多容器应用。它的核心价值在于:用一个 YAML 文件取代一连串手动的 docker run 命令,使得复杂应用的启动、停止和重建变得一键可达。
对于开发团队而言,Compose 解决了三个关键问题:环境一致性(“在我机器上能跑”的问题)、服务依赖管理(确保数据库在应用之前启动)、以及开发-测试-生产的配置差异管理(通过 compose.override.yaml 实现多环境适配)。
Compose 模板文件采用 YAML 格式,扩展名为 .yml 或 .yaml。
注意:Compose Specification 的顶层
version字段仅用于向后兼容,当前已标记为 obsolete。新文件建议直接省略该字段。
Docker Compose 默认使用 compose.yaml,也兼容 compose.yml、docker-compose.yaml、docker-compose.yml 等文件名。
Compose 中有两个重要的概念:
服务 (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
项目 (project):由一组关联的应用容器组成的一个完整业务单元,在 Compose 文件中定义。
Compose 的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。
Compose 项目早期由 Python 编写,称为 Docker Compose V1。
现在的 Docker Compose V2 是一个 Go 语言编写的 Docker CLI 插件(当前版本号已演进至 v5.x 系列,以避免与旧 Compose 文件格式版本混淆)。Docker Desktop 默认包含它;在 Linux 上,也可以将它作为独立的 CLI 插件安装后直接通过 docker compose 命令使用。它提供了更快的性能和更好的集成体验。
只要所操作的平台支持 Docker API,就可以在其上利用 Compose 来进行编排管理。