一 简介
- Docker Compose是一个能一次性定义和管理多个Docker容器的工具。
- Compose中定义和启动的每一个容器都相当于一个服务(service)。
- Compose中能定义和启动多个服务,且它们之间通常具有协同关系
管理方式:
-
使用YAML文件来配置我们应用程序的服务。
-
使用单个命令(docker-compose up),就可以创建并启动配置文件中配置的所有服务。
Docker Compose安装
# 第一步:
sudo curl -L "https://github.com/docker/compose/releases/download/2.14.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
第二步:
sudo chmod +x /usr/local/bin/docker-compose
终端中使用docker-compose --version查看安装的版本
国内镜像:
curl -L https://get.daocloud.io/docker/compose/releases/download/2.14.2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
二 Docker Compose File TOP配置参数概览
Docker Compose File 顶级配置项:
version:指定Docker Compose File版本号
services:定义多个服务并配置启动参数
volumes:声明或创建在多个服务中共同使用的数据卷对象
networks:定义在多个服务中共同使用的网络对象
configs:声明将在本服务中要使用的一些配置文件
secrets:声明将在本服务中要使用的一些秘钥、密码文件
x-***:自定义配置。主要用于复用相同的配置。
一个service代表一个container,这个container可以从dockerhub的image来创建,或者从本地dockerfilebuild的image来创建。
service的启动类似docker run,可以指定network和volume,所有可以给servier指定network和volume。
三 docker-compose命令
docker-compose up # 会自动搜索当前路径下的 docker-compose.yml文件
docker-compose -f 指定文件 up
docker-compose up -d # 后台执行,一般我们看日志输出,不用这个
docker-compose stop # 停止,不会删除容器和镜像
docker-compose down # 停止,并删除关联的容器
docker-compose start # 启动yml文件管理的容器
docker-compose ps # 正在运行的容器
docker-compose images # docker-compose管理的容器
docker-compose exec yml文件中写的service /bin/bash # 进入到容器内
四 docker-compose部署flask项目
1. 编写docker-compose.yml文件
version: "3"
services:
redis:
image: redis
web:
build:
context: .
dockerfile: Dockerfile
ports:
- 8080:5000
environment:
REDIS_HOST: redis
2. 编写Dockerfile文件
FROM python:3.8
COPY . /app
WORKDIR /app
RUN pip install flask redis -i https://pypi.tuna.tsinghua.edu.cn/simple
EXPOSE 5000
CMD [ "python", "app.py" ]
3. 编写app.py
from flask import Flask
from redis import Redis
import os
import socket
app = Flask(__name__)
redis = Redis(host=os.environ.get('REDIS_HOST', '127.0.0.1'), port=6379)
@app.route('/')
def hello():
redis.incr('hits')
return '你好! 查看 %s 次, hostname 是 %s.\n' % (redis.get('hits'),socket.gethostname())
if __name__ == "__main__":
app.run(host="0.0.0.0", port=5000, debug=True)
一键部署:redis,和flask ,每个都在一个容器中
docker-compose up