赵强老师使用Docker-Compose进行服务编排

38次阅读

共计 2217 个字符,预计需要花费 6 分钟才能阅读完成。

一、什么是 Docker Compose?

Docker Compose 是一个用来定义和运行复杂应用的 Docker 工具。一个使用 Docker 容器的应用,通常由多个容器组成。使用 Docker Compose 不再需要使用 shell 脚本来启动容器,而使用服务编排的方式来管理容器。
Docker Compose 通过一个配置文件来管理多个 Docker 容器,在配置文件中,所有的容器通过 services 来定义,然后使用 docker-compose 脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。

Docker Compose 的核心是通过一个 YAML 文件来管理多个 Docker 容器,在配置文件中,所有的容器通过 services 来定义。

二、什么是 YAML 文件?

YAML(YML)的意思其实是:”Yet Another Markup Language”(仍是一种置标语言)的缩写。YAML 的语法和其他高阶语言类似,并且可以简单表达清单、散列表,标量等资料形态。它使用空格缩排和大量依赖外观的特色,特别适合用来表达或编辑数据结构、各种设定档、倾印除错内容、文件大纲(例如:许多电子邮件标题格式和 YAML 非常接近)。可以是用 .yml 或 .yaml 作为文件扩展名。

三、部署 Docker Compose

  • 官方文档:https://docs.docker.com/compo…
  • 执行下面的语句进行安装
curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m)" \
-o /usr/local/bin/docker-compose

chmod +x /usr/local/bin/docker-compose
docker-compose --version

四、使用 Docker Compose 构建 Python Web 应用

这里,我们将使用两种不同的方式:手动部署和利用 Docker Compose 部署,来说明使用 Docker Compose 进行部署所带来的好处。

  • 首先,我们需要创建我们的应用程序,实现一个简单的计数器功能。这里我们需要创建三个文件:app.py、requirements.txt 和 Dockerfile,具体内容如下。
##app.py 应用程序代码
from flask import Flask
from redis import Redis
import os
app = Flask(__name__)
redis = Redis(host='redis', port=6379)
 
@app.route('/')
def hello():
    redis.incr('hits')
    return 'Hello World! I have been seen %s times.' % redis.get('hits')
 
if __name__ == "__main__":
    app.run(host="0.0.0.0", debug=True)
    
-----------------------------------------    
##requirements.txt 文件内容
flask
redis

-----------------------------------------    
##Dockerfile 文件内容
FROM python:3.4-alpine
ADD . /code
WORKDIR /code
COPY app.py /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]
  • 手动部署应用程序
## 由于应用程序中,需要 redis 的支持,首先启动一个 Redis 容器
docker run --name myredis -d -p 6379:6379 redis

## 使用 docker build 编译 Dockerfile
docker build -t myapplication .

## 使用 docker run 命令启动应用程序,并使用 --link 参数连接到上面的 redis 容器中
docker run --name myapp_using_redis -p 5000:5000 --link myredis:redis -d myapplication
其中:--link 参数中的:myredis:是上面的启动的 Redis 容器
redis:是这个 Redis 的容器的别名(可以看成是 HostName)## 通过网址 http://192.168.15.133:5000 访问应用程序
## 刷新页面,计数器会自增。

  • 利用 docker-compose 快速部署 Python 开发环境

而事实上,我们可以使用更加简化的方式来定义我们的容器组合管理,使用 Docker-compose 来定义我们的容器组合关系。目录结构下,包含以下文件:

其中,docker-compose.yml 文件内容如下:

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

执行 docker-compose up 来启动应用,访问应用程序:http://192.168.15.133:5000/

从这里例子中我们可以看到,通过 Docker Compose 的 YAML 配置文件,我们把两个相关的 Service(web 和 redis)进行了服务编排,从而简化的应用的部署。

正文完
 0