Docker-Compose

一 简介

  • 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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值