Docker Compose

Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。
Compose 定位是**定义和运行多个Docker容器的应用。
我们知道使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个Web项目,除了Web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
Compose恰好满足了这样的需求。它允许用户通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的应用容器为一个项目。

Compose中两个重要的概念:

  • (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
  • 项目 (project):由一组关联的应用容器组成的一个完整业务单元,在docker-compose.yml文件中定义。
    Compose的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。
    Compose项目由Python编写,实现上调用了Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose来进行编排管理。

安装

Mac和Window平台下载后自带docker-composer,可以通过以下命令查看:

docker-composer --version

Linux安装

$ sudo curl -L https://github.com/docker/compose/releases/download/1.17.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
$ sudo chmod +x /usr/local/bin/docker-compose

卸载

sudo rm /usr/local/bin/docker-compose

使用

docker-compose 命令的基本的使用格式是:

docker-compose [-f=<arg>...] [options] [COMMAND] [ARGS...]

命令选项:
-f, –file FILE指定使用的Compose模板文件,默认为docker-compose.yml,可以多次指定。
-p, –project-name NAME指定项目名称,默认将使用所在目录名称作为项目名。
–x-networking 使用Docker的可拔插网络后端特性
–x-network-driver DRIVER指定网络后端的驱动,默认为bridge
–verbose 输出更多调试信息。
-v, –version 打印版本并退出。

compose命令

常用命令如下:
down
此命令将会停止 up 命令所启动的容器,并移除网络

exec
进入指定的容器。

up

格式为docker-compose up [options] [SERVICE...]
该命令将尝试自动完成包括构建镜像,(重新)创建服务,启动服务,并关联服务相关容器的一系列操作。
链接的服务都将会被自动启动,除非已经处于运行状态。
大部分时候都可以直接通过该命令来启动一个项目。
默认情况,docker-compose up启动的容器都在前台,控制台将会同时打印所有容器的输出信息,可以很方便进行调试。
当通过Ctrl-C停止命令时,所有容器将会停止。
如果使用docker-compose up -d,将会在后台启动并运行所有的容器。一般推荐生产环境下使用该选项。
默认情况,如果服务容器已经存在,docker-compose up将会尝试停止容器,然后重新创建(保持使用volumes-from挂载的卷),以保证新启动的服务匹配docker-compose.yml文件的最新内容。如果用户不希望容器被停止并重新创建,可以使用docker-compose up --no-recreate,这样将只会启动处于停止状态的容器,而忽略已经运行的服务。如果用户只想重新部署某个服务,可以使用docker-compose up --no-deps -d <SERVICE_NAME>来重新创建服务并后台停止旧服务,启动新服务,并不会影响到其所依赖的服务。
选项:

  • -d:在后台运行服务容器。
  • --no-color:不使用颜色来区分不同的服务的控制台输出。
  • --no-deps:不启动服务所链接的容器。
  • --force-recreate强制重新创建容器,不能与--no-recreate同时使用。
  • --no-recreate如果容器已经存在了,则不重新创建,不能与--force-recreate同时使用。
  • --no-build不自动构建缺失的服务镜像。
  • -t, --timeout TIMEOUT停止容器时候的超时(默认为10秒)。

Compose模版文件

模板文件是使用Compose的核心,默认的模板文件名称为docker-compose.yaml格式为YAML格式。
Compose模版文件指令说明

docker-compose配置mysql

version: '3.1' # docker-compose版本
services: # 服务
  mysql:  # 服务名称(可以自定义)
    image: mysql # 镜像
    restart: always # 总是重启
    container_name: mysql # 容器名称
    ports:
      - 3306:3306 # 映射端口
    environment:
      TZ: Asia/Shanghai # 时区
      MYSQL_ROOT_PASSWORD: 123456 # Root账户密码
    command:
      --default-authentication-plugin=mysql_native_password
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
      --explicit_defaults_for_timestamp=true
      --lower_case_table_names=1
      --max_allowed_packet=128M
    volumes: # 数据卷映射
      - /Users/xiaoming/mysql-data:/mysql-data
  adminer: # mysql界面管理
    image: adminer
    restart: always
    ports:
      - 8080:8080

每个服务都必须通过image指令指定镜像或build指令(需要 Dockerfile)等来自动构建生成镜像。
如果使用build指令,在Dockerfile中设置的选项(例如:CMD, EXPOSE, VOLUME, ENV等) 将会自动被获取,无需在 docker-compose.yml 中再次设置。