docker compose安装和体验

简介

Compose 是用于定义和运行多容器 Docker 应用程序的工具。使用 Compose,您可以使用 YAML 文件来配置应用程序的服务。
编写工作在所有环境中:生产、过渡、开发、测试以及 CI 工作流。

使用撰写基本上是一个三步过程:
1.使用 定义应用的环境,以便可以在任何位置复制它。
*Dockerfile保证我们的项目在任何地方可以运行。
2.定义组成应用的服务,以便它们可以在隔离的环境中一起运行。
3.运行后,Docker 撰写命令将启动并运行整个应用。或者,您可以使用 docker 组合二进制文件运行。

docker-compose.yml

version: "3" 
services:
  web:
    build: .
    ports:
      - "8000:5000"
    volumes:
      - .:/code
      - logvolume01:/var/log
    links:
      - redis
  redis:
    image: redis
volumes:
  logvolume01: {}

安装docker Compose

下载

curl -L https://get.daocloud.io/docker/compose/releases/download/v2.5.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

授权

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

测试安装结果

docker-compose --version

开始体验docker-compose

官网
1.为项目创建一个目录

mkdir /date/composetest -p
cd /date/composetest

2.创建一个在项目目录中调用的文件: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)

3.在项目目录中创建另一个被会被调用的文件:requirements.txt

flask
redis

4.创建docker文件:Dockerfile

FROM python:3.7-alpine
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]

这告诉 Docker:
从 Python 3.7 映像开始构建映像。
将工作目录设置为 。/code
复制并安装 Python 依赖项。requirements.txt
将容器的默认命令设置为 。python app.py

5.创建一个在项目目录中调用的文件:docker-compose.yml

version: "3.9"
services:
  web:
    build: .
    ports:
      - "5000:5000"
  redis:
    image: "redis:alpine"

6.从项目目录中,通过运行启动应用程序。

docker-compose up

docker小结:
1、Docker镜像。run => 容器
2、Dockerfile构建镜像(服务打包)
3、docker-compose启动项目(编排、多个微服务/环境)
4、Docker网络

yaml 规则

docker-compose.yaml核心。!

#yaml文件三层
version:‘’  #第一层版本
services:    #第二层服务
	服务1:web
		#服务配置 docker容器配置
		images
		build
		network
		...
	服务2:redis
	...
	服务3:redis
	...
#第三层其他配置  网络/卷、全局规则
volumes:
network:
configs:

启动顺序
先启动redis在启动web

实战过程

1、编写项目微服务
2、dockerfile构建镜像
3、docker-compose.yaml编排项目
4、传到服务器

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值