Loading

使用Docker Compose运行多个Docker应用

Docker Compose 概述

Compose 是一个用于定义和运行多容器 Docker 应用程序的工具。借助 Compose,您可以使用 YAML 文件来配置应用程序需要的服务。然后,使用单个命令就可以从YML配置中创建并启动所有服务。使用Docker Compose可以方便、高效的管理容器。

官方文档:https://docs.docker.com/compose/

使用 Compose 的三个步骤:

  1. 使用 Dockerfile 定义应用程序的环境。
  2. 使用docker-compose.yml定义应用程序的服务,这样就可以在隔离的环境中一起运行。
  3. 运行docker-compose up命令启动并运行整个应用程序。

安装Docker Compose

Linux环境下安装Compose。

  1. 安装Compose:
$ sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
  1. 对二进制文件应用可执行权限:
$ sudo chmod +x /usr/local/bin/docker-compose
  1. 测试安装是否成功:
$ docker-compose --version
docker-compose version 1.29.2, build 1110ad01

Docker Compose入门案例

体验官方示例:https://docs.docker.com/compose/gettingstarted/

第一步:设置

  1. 为项目创建一个目录
 mkdir composetest
 cd composetest
  1. 新建app.py文件
import time

import redis
from flask import Flask

app = Flask(__name__)
cache = redis.Redis(host='redis', port=6379)

def get_hit_count():
    retries = 5
    while True:
        try:
            return cache.incr('hits')
        except redis.exceptions.ConnectionError as exc:
            if retries == 0:
                raise exc
            retries -= 1
            time.sleep(0.5)

@app.route('/')
def hello():
    count = get_hit_count()
    return 'Hello World! I have been seen {} times.\n'.format(count)
  1. 将依赖添加到requirements.txt
flask
redis

第二步:创建 Dockerfile 文件

FROM python:3.7-alpine
WORKDIR /code
ENV FLASK_APP=app.py
ENV FLASK_RUN_HOST=0.0.0.0
RUN apk add --no-cache gcc musl-dev linux-headers
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
EXPOSE 5000
COPY . .
CMD ["flask", "run"]

第三步:在 Compose 文件中定义服务

新建 docker-compose.yml文件并粘贴以下内容

version: "3"
services:
  web:
    build: .
    ports:
      - "5000:5000"
  redis:
    image: "redis:alpine"

第四步:使用 Compose 构建并运行您的应用程序

$ docker-compose up

-d参数:后台执行该服务

在浏览器中输入 http://localhost:5000/ 以查看应用程序正在运行。

Docker Compose常用命令

停止 Compose:

docker-compose stop

关闭 Compose:

docker-compose down

删除已停止的 Compose 应用:

docker-compose rm

重启已停止的 Compose 应用:

docker-compose restart

常用配置

Docker Compose File 的顶级配置项:

  • version:指定Compose版本
  • services:定义多个服务并配置启动参数
  • volumes:声明或创建在多个服务中共同使用的数据卷对象
  • networks:定义在多个服务中共同使用的网络
  • configs:声明将在本服务中要使用的一些配置文件
  • secrets:声明将在本服务中要使用的一些密钥、密码文件
  • x-***:自定义配置,主要用来复用相同的配置

更多详细配置可以参考官方文档:https://docs.docker.com/compose/compose-file/compose-file-v3/

posted @ 2021-08-18 10:23  charlatte  阅读(466)  评论(0编辑  收藏  举报