目录
前言
- 我们知道使用一个 Dockerfile 模板文件一次只能够定义一个单独的应用容器(镜像),如果需要定义多个容器就需要使用服务编排技术。
- Docker Compose 是 Docker 的官方产品 ,用来对多个容器进行服务编排。
- Dockerfile 可以让用户管理一个单独的应用容器;而 Compose 则允许用户在一个模板(yaml格式)中定义一组上下相关联的应用容器(被称为一个 project,即项目),例如一个 web项目由apache容器 + 后端的Mysql数据库容器 + php容器组成。
一、Docker-Compose 简介
Docker-Compose 用来实现Docker容器快速编排
- 通过 Compose,不需要使用shell脚本来启动容器,而使用 YAML 文件来配置应用程序需要的所有服务,然后使用一个命令,根据 YAML 的文件配置创建并启动所有服务。
- Docker-Compose 项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。
- Docker-Compose 将所管理的容器分为三层:
- 工程(project):一个工程包含多个服务
- 服务(service):一个服务当中可包括多个容器实例
- 容器(container)
- Docker-Compose 运行目录下的所有文件(docker-compose.yml、extends文件 或 环境变量文件等)组成一个工程,若无特殊指定 工程名即为当前目录名。
- 一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖。
- 一个服务当中可包括多个容器实例,**但是:Docker-Compose 并没有解决负载均衡的问题,**因此需要借助其它工具实现服务发现及负载均衡,比如 Consul 技术。
- Docker-Compose 的工程配置文件默认为 docker-compose.yml,可通过环境变量
COMPOSB_FILE
或-f
参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。 - 使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个wieb项目,除了web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
- Compose 允许用户通过一个单独的 docker-compose.yml 模板文件(YAML格式)来定义一组相关联的应用容器为一个项目 (project)。
- Docker-Compose 项目由 Python 编写,调用 Docker 服务提供的API来对容器进行管理。因此,只要所操作的平台支持 Docker API,就可以在其上利用Compose 来进行编排管理。
二、YAML 文件格式 及 编写注意事项
- yaml 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于XML数据描述语言,语法比 XMAL简单的很多。
- YAML数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号
[]
括起来, hash用花括号{}
括起来。
使用 YAML时需要注意下面事项:
● 使用缩进表示层级关系,不支持制表符tab键缩进,只能使用空格键缩进;
● 缩进长度没有限制,只要元素对齐就表示这些元素属于一个层级
● 通常开头缩进2个空格;
● 字符后缩进1个空格,如冒号:空格
逗号,空格
横杠-空格
文本之间的空格>
;
● 用#号注释;
● 如果包含特殊字符用单引号' '
引起来;
● 布尔值必须用引号" "
括起来;
● 区分大小写
● 字符串可以不用引号标注
YAML支持的数据结构:
- 对象:键值对的集合,又称为映射(map)/ 哈希(hashes) / 字典(dictionary)
# YAML表示
age : 12
name : huang
# 对应的Json表示
{
'age':12,'name':'huang'}
- 数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
使用连字符(-)表示:
#