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 打印版本并退出。
常用命令如下: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 中再次设置。