啃Docker之Docker Compose容器编排
一:Docker Compose容器编排
1.1:什么是Docker Compose?
-
Docker Compose 的前身是Fig,它是一个定义及运行多个容器的工具
-
Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排。
使用前面介绍的Dockerfile文件可以很容易定义一个单独的应用容器。然而在日常开发工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。
例如要实现一个 Web 项目,除了 Web 服务容器本身,往往还需要再加上后端的数据库服务容器;再比如在分布式应用一般包含若干个服务,每个服务一般都会部署多个实例。
如果每个服务都要手动启停,那么效率之低、维护量之大可想而知。这时候就需要一个工具能够管理一组相关联的的应用容器,这就是Docker Compose。- Compose有2个重要的概念:
- 项目(Project):由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml 文件中定义。
- 服务(Service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
1.2:Docker Compose的作用
- 使用Docker Compose不再需要使用shell脚本来启动容器
- 通过Docker Compose可以使用YML文件来配置应用程序所需要的的所有服务
- Docker Compose非常适合组合使用多个容器进行开发的场景
1.3:YML文件
-
YAML是一种标记语言很直观的数据序列化格式,非常适合用来表达或者编辑数据结构、各种配置文件、文件大纲等,例如:许多电子邮件标题格式和YAML非常接近
-
文件格式以及编写注意事项
- 1、不支持制表符tab键缩进,需要使用空格缩进,使用缩进表示层级关系
- 2、通常开头缩进2个空格,缩进的空格数不重要,只要相同层级的元素左对齐即可
- 3、字符后缩进一个空格,如冒号、逗号、横杆
- 4、用
#
号注释 - 5、如果包含特殊字符用单引号引起来
- 6、布尔值必须用引号括起来
1.4:使用Docker Compose详解:使用步骤、环境准备、格式详解
-
compose使用的三个步骤
- 1、使用Dockerfile定义应用程序的环境
- 2、使用docker-compose.yml定义构成应用程序的服务,这样它们可以在隔离环境中一起运行
- 3、最后执行docker-compose up命令来启动并运行整个应用程序
-
Docker compose环境准备
[root@docker ~]# curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose '在Linux上我们可以从GitHub上下载它的二进制包来使用,此命令是下载Docker Compose的当前稳定版本'
[root@docker ~]# chmod +x /usr/local/bin/docker-compose
[root@docker ~]# docker-compose -v
docker-compose version 1.21.1, build 5a3f1a3
- Docker Compose文件结构举例:docker-compose.yml
- 1、compose版本号、服务标识符必须顶格写
- 2、属性名与属性值以
:
(冒号加空格)分隔开 - 3、层级使用两个空格表示
- 4、服务属性使用
-
(空格空格-空格)表示
version: '3' 'compose版本号'
services: '服务标识符'
nginx: '子服务名'
hostname: nginx '主机名'
build:
context: ./nginx
dockerfile: Dockerfile
ports: '服务端口属性'
- 1216:80
- 1217:443
networks: '网络服务属性'
- yun
volumes: '挂载一个目录或者一个已存在的数据卷容器'
- ./wwwroot:/usr/local/nginx/html
networks:
yun:
1.5:Docker Compose配置常用字段
字段 | 描述 |
---|---|
build dockerfile context | 指定Dockerfile文件名构建镜像上下文路径 |
image | 指定镜像 |
command | 执行命令,覆盖默认命令 |
container name | 指定容器名称,由于容器名称是唯一的,如果指定 自定义名称,则无法scale |
deploy | 指定部署和运行服务相关配置,只能在swarm模式适用 |
environment | 添加环境变量 |
networks | 加入网络 |
ports | 暴露容器端口,与-p相同,但端口不能低于60 |
volumes | 挂载宿主机路径或命令卷 |
restart | 重启策略,默认no,always,no-failure,unl |