docker_practice/compose/introduction.md

22 lines
1.7 KiB
Go
Raw Normal View History

# Compose 简介
2015-05-08 12:10:01 +00:00
2017-11-26 01:54:04 +00:00
`Compose` 项目是 Docker 官方的开源项目负责实现对 Docker 容器集群的快速编排从功能上看 `OpenStack` 中的 `Heat` 十分类似
2015-05-08 12:10:01 +00:00
2016-12-20 07:35:52 +00:00
其代码目前在 [https://github.com/docker/compose](https://github.com/docker/compose) 上开源。
2015-05-08 12:10:01 +00:00
2017-11-26 01:54:04 +00:00
`Compose` 定位是 定义和运行多个 Docker 容器的应用Defining and running multi-container Docker applications其前身是开源项目 Fig
2016-12-20 07:35:52 +00:00
2017-11-23 07:48:52 +00:00
通过第一部分中的介绍我们知道使用一个 `Dockerfile` 模板文件可以让用户很方便的定义一个单独的应用容器然而在日常工作中经常会碰到需要多个容器相互配合来完成某项任务的情况例如要实现一个 Web 项目除了 Web 服务容器本身往往还需要再加上后端的数据库服务容器甚至还包括负载均衡容器等
2016-12-20 07:35:52 +00:00
2017-11-26 01:54:04 +00:00
`Compose` 恰好满足了这样的需求它允许用户通过一个单独的 `docker-compose.yml` 模板文件YAML 格式来定义一组相关联的应用容器为一个项目project
2016-12-20 07:35:52 +00:00
2017-11-26 01:54:04 +00:00
`Compose` 中有两个重要的概念
2016-12-20 07:35:52 +00:00
2017-11-29 02:24:19 +00:00
* 服务 (`service`)一个应用的容器实际上可以包括若干运行相同镜像的容器实例
2017-11-23 07:48:52 +00:00
2017-11-29 02:24:19 +00:00
* 项目 (`project`)由一组关联的应用容器组成的一个完整业务单元 `docker-compose.yml` 文件中定义
2016-12-20 07:35:52 +00:00
2017-11-26 01:54:04 +00:00
`Compose` 的默认管理对象是项目通过子命令对项目中的一组容器进行便捷地生命周期管理
2016-12-20 07:35:52 +00:00
2017-11-26 01:54:04 +00:00
`Compose` 项目由 Python 编写实现上调用了 Docker 服务提供的 API 来对容器进行管理因此只要所操作的平台支持 Docker API就可以在其上利用 `Compose` 来进行编排管理