11Docker容器服务编排利器 Docker Compose应用实战

3 阅读3分钟

Docker容器服务编排利器 Docker Compose应用实战

使用Docker Compose必要性及定义

用容器运行一个服务,需要使用docker run命令。但如果我要运行多个服务呢?

假设我要运行一个web服务,还要运行一个db服务,那么是用一个容器运行,还是用多个容器运行呢?

一个容器运行多个服务会造成镜像的复杂度提高,docker倾向于一个容器运行一个应用

那么复杂的架构就会需要很多的容器,并且需要它们之间有关联(容器之间的依赖和连接)就更复杂了。

这个复杂的问题需要解决,这就涉及到了容器编排的问题了。

  • Compose 编排

    • 是对多个容器进行启动和管理的方法
    • 例如:LNMT,先启动MySQL,再启动Tomcat,最后启动Nginx
  • 服务架构的演进

    • 单体服务架构
    • 分布式服务架构
    • 微服务架构
    • 超微服务架构
  • 容器编排工具

    • docker machine 在虚拟机中部署docker容器引擎的工具

    • docker compose 是一个用于定义和运行多容器Docker的应用程序工具

    • docker swarm 是Docker Host主机批量管理及资源调度管理工具

    • mesos+marathon

      • mesos 对计算机计算资源进行管理和调度
      • marathon 服务发现及负载均衡的功能
    • kubernetes google开源的容器编排工具

    Docker Compose官网 docs.docker.com/compose/

Docker Compose应用最佳实践步骤

概念

  • 工程(project)
  • 服务 (Service)
  • 容器 (Container)

步骤

  • 定义应用的Dockerfile文件,为了anywhere进行构建。
  • 使用docker-compose.yaml定义一套服务,这套服务可以一起在一个隔离环境中运行。
  • 使用docker-compose up就可以启动整套服务。

Docker Compose安装见上面的harbor章节

Docker Compose应用案例

运行Python语言开发的网站

网站文件准备

mkdir flaskproject
cd flaskproject/
# 创建 requirements.txt 文件,内容如下
cat requirements.txt
flask
redis
# 创建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)

Dockerfile文件准备

# 创建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
COPY . .
CMD ["flask", "run"]

Compose文件准备

# 创建docker-compose.yaml文件,内容如下
version: '3'
services:
  web:
    build: .
    ports:
      - "5000:5000"
  redis:
    image: "redis:alpine"

使用docker-compose up启动容器

ls
app.py  docker-compose.yaml  Dockerfile  requirements.txt

docker-compose up
...
flaskproject-web-1    |  * Serving Flask app 'app.py'
flaskproject-web-1    |  * Debug mode: off
flaskproject-web-1    | WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
flaskproject-web-1    |  * Running on all addresses (0.0.0.0)
flaskproject-web-1    |  * Running on http://127.0.0.1:5000
flaskproject-web-1    |  * Running on http://172.19.0.3:5000
flaskproject-web-1    | Press CTRL+C to quit

# 按 CTRL+C 会退出并停止,使用下面的命令在后台启动
docker-compose up -d

curl 127.0.0.1:5000
Hello World! I have been seen 1 times.

curl 127.0.0.1:5000
Hello World! I have been seen 2 times.

curl 127.0.0.1:5000
Hello World! I have been seen 3 times.