Docker 学习笔记3 - docker-compose(编排) 简介

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 将会用来编译镜像
  • 环境变量指定了容器的端口映射规则、环境变量等。

常用指令

编译,执行构建
可使用 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]
停止和删除容器、网络、卷、镜像。

2. 参考

https://docs.docker.com/compose/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值