Docker-compose


Docker-Compose 是 Docker 官方的开源项目,负责实现对Docker容器集群的快速编排。

Docker-Compose可以管理多个Docker容器组成一个应用。需要定义一个yaml格式的配置文件 docker-compose.yml,配置好多个容器之间的调用关系,然后只需要一个命令就能同时启动/关闭这些容器。

Docker建议我们每个容器中只运行一个服务,因为Docker容器本身占用资源极少,所以最好是将每个服务单独的分割开来。但是如果我们需要同时部署多个服务,每个服务单独构建镜像构建容器就会比较麻烦。所以 Docker 官方推出了 docker-compose 多服务部署的工具。

Compose允许用户通过一个单独的 docker-compose.yml 模板文件来定义一组相关联的应用容器为一个项目(project)。可以很容易的用一个配置文件定义一个多容器的应用,然后使用一条指令安装这个应用的所有依赖,完成构建。

核心概念:

●服务(service):一个个应用容器实例
●工程(project):由一组关联的应用容器组成的一个完整业务单元,在docker-compose.yml中定义

Compose使用的三个步骤:

1 . 编写 Dockerfile 定义各个应用容器,并构建出对应的镜像文件
2 . 编写 docker-compose.yml,定义一个完整的业务单元,安排好整体应用中的各个容器服务
3 . 执行docker-compose up 命令,其创建并运行整个应用程序,完成一键部署上线

常用命令


执行命令时,需要在对应的docker-compose.yml文件所在目录下执行。

docker-compose -h # 查看帮助
docker-compose up # 启动所有docker-compose服务
docker-compose up -d # 启动所有docker-compose服务并后台运行
docker-compose down # 停止并删除容器、网络、卷、镜像。
docker-compose exec yml里面的服务id # 进入容器实例内部 docker-compose exec docker-compose.yml文件中写的服务id /bin/bash
docker-compose ps # 展示当前docker-compose编排过的运行的所有容器
docker-compose top # 展示当前docker-compose编排过的容器进程

docker-compose logs yml里面的服务id # 查看容器输出日志
docker-compose config # 检查配置
docker-compose config -q # 检查配置,有问题才有输出
docker-compose restart # 重启服务
docker-compose start # 启动服务
docker-compose stop # 停止服务

查看帮助:

  1. docker-compose -h

创建并启动docker-compose服务:(类似 docker run)

  1. docker-compose up
  2. # 后台运行
  3. docker-compose up -d

停止并删除容器、网络、卷、镜像:(类似 docker stop + docker rm)

  1. docker-compose down

进入容器实例内部:

  1. docker-compose exec <yml里面的服务id> /bin/bash

展示当前编排过的运行的所有容器:

  1. docker-compose ps

展示当前编排过的容器进程:

  1. docker-compose top

查看容器输出日志:

  1. docker-compose log <yml里面的服务id>

检查配置:

  1. docker-compose config
  2. # 有问题才输出
  3. docker-compose config -q

重启、启动、停止服务:

  1. docker-compose restartstart,stop

compose编排实例