0. 背景
docker-compose 可将多个 “docker容器” 组成一组。这样它们就可以在一个隔离的环境中一起运行。
1. 介绍
docker-compose: 可以用于定义一个组,方便于帮助运行多容器组的工具。它使用YAML文件来配置应用程序的服务,然后就可以用一个命令,从配置中创建并启动所有服务。
一般来说,把微服务 Docker 化后,在要想启动微服务的容器时,不得不手动逐个启动各个容器,服务多了以后,管理起来十分麻烦。用 docker-compose 来解决一些多容器管理的问题。
yaml 文件
docker-compose 工具能直接用一个 docker-compose.yaml
来编排管理多个容器,可以设置各容器的 环境变量
,配置 service
配置项,就像 docker run
命令一样来启动容器。举个例子:
以前用 docker 命令管理容器:
$ docker run -p 50052:50051 \
-e MICRO_SERVER_ADDRESS=:50051 \
-e MICRO_REGISTRY=mdns \
vessel-service
等效于 docker-compose 来管理:
version: '3.1'
vessel-service:
build: ./vessel-service
ports:
- 50052:50051
environment:
MICRO_ADRESS: ":50051"
MICRO_REGISTRY: "mdns"
想加减和配置微服务,直接修改 docker-compose.yaml,十分方便。
使用 docker-compose 的步骤
使用 docker-compose 基本上是一个三步的过程:
- (1)为各个子服务编写Dockerfile
- (2)编写docker-compose文件:在docker-compose中定义组成应用程序的服务。这样它们就可以在一个隔离的环境中一起运行。
- (3)运行docker-compose up和Compose started并运行整个应用程序。
内容说明
参考上面的示例,可以看到:
- version 关键字:指定了 docker-compose 的版本是 3.1
- services: 使用 services 来定义多个服务,每个微服务都定义了自己容器的名字
- build 指定目录下的 Dockerfile 将会用来编译镜像
- 环境变量指定了容器的端口映射规则、环境变量等。
常用指令
常用这些:
- build 构建或重建服务
- help 命令帮助
- kill 杀掉容器
- logs 显示容器的输出内容
- port 打印绑定的开放端口
- ps 显示容器
- pull 拉取服务镜像
- restart 重启服务
- rm 删除停止的容器
- run 运行一个一次性命令
- scale 设置服务的容器数目
- start 开启服务
- stop 停止服务
- up 创建并启动容器
编译,执行构建
可使用 docker-compose build 来编译生成三个对应的镜像;
运行
使用 docker-compose run 来运行指定的容器
后台运行
docker-compose up -d 可在后台运行;
列出项目中所有的容器
docker-compose ps [options] [SERVICE...]
停止
使用 docker stop $(docker ps -aq ) 来停止所有正在运行的容器。
或者直接: docker-compose stop
** 停止和删除容器**
docker-compose down [options]
停止和删除容器、网络、卷、镜像。
网友评论