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.