Docker编排工具Compose详解
Docker编排意味着用户可以灵活地对各种容器资源实现定义和管理,Compose作为Docker官方编排工具,可以让用户通过编写一个简单的模板文件,快速地创建和管理基于Docker容器的应用集群。
使用Compose模板文件,用户可以编写包括若干服务的一个模板文件快速启动服务栈。分发给他人也可快速创建一套相同的服务栈。
一、Compose简介
Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的应用容器为一个服务栈(stack)。
Compose中重要的概念:
- 任务(task):一个容器被称为一个任务。任务拥有独一无二的ID,在同一个服务中的多个任务序号依次递增。
- 服务(service):某个相同应用镜像的容器副本集合,一个服务可以横向扩展为多个容器实例。
- 服务栈(stack):由多个服务组成,相互配合完成特定业务,如web应用服务、数据库服务共同构成Web服务栈,一般由一个docker-compose.yml文件定义。
Compose的默认管理对象是服务栈,通过子命令对栈中的多个服务进行便捷的生命周期管理。
Compose项目由Python编写,实现上调用了Docker服务提供的API来对容器进行管理。因此只要操作的平台支持Do