Docker之Docker-Compose

Docker之Docker-Compose

一 Docker Compose 简介

1 Docker Compose介绍

• Docker Compose是一个能一次性定义和管理多个Docker容器的工具。

• 详细地说:

Docker-compose是容器编排工具,需要注意的是,docker-compose只是单机的容器编排工具。

• 管理方式:

使用YAML文件来配置我们应用程序的服务。默认名字 docker-compose.yaml

使用单个命令(docker-compose up),就可以创建并启动配置文件中配置的所有服务。

2 Docker Compose 工作原理

在这里插入图片描述

3 Docker Compose安装

# Docker for Mac与Docker for Windows自带docker-compose
# Linux下需要单独安装:
# 第一步: sudo curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
# 第二步:sudo chmod +x /usr/local/bin/docker-compose
# 终端中使用docker-compose --version查看安装的版本
这里示例安装版本是1.21.2,已经出现更新的版本,因此建议换成最新版本。
# 访问github可能网络原因下载失败,可以使用国内镜像
curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.4/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
# 命令补全
curl -L https://raw.githubusercontent.com/docker/compose/1.25.5/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose

4 Docker Compose CLI

利用docker-compose --help查看

对比后会发现:Docker Compose CLI的很多命令的功能和Docker Client CLI是相似的。最主要的区别就是前者能一次性运行管理多个容器,后者只能一次管理一个。

二 了解 Docker Compose File

1 Docker Compose File版本

Docker Compose File 有多个版本,基本是向后兼容的,但也有极个别配置项高版本中没有。

• 在docker-compose.yml一开始就需要利用version关键词标明当前file使用的版本

在这里插入图片描述

2 Docker Compose File TOP配置参数概览

Docker Compose File 顶级配置项:

•version:指定Docker Compose File版本号

•services:定义多个服务并配置启动参数

•volumes:声明或创建在多个服务中共同使用的数据卷对象

•networks:定义在多个服务中共同使用的网络对象(用于容器间网络通信)

•configs:声明将在本服务中要使用的一些配置文件

•secrets:声明将在本服务中要使用的一些秘钥、密码文件

•x-***:自定义配置。主要用于复用相同的配置。

•healthcheck:用于容器健壮性性校验

-version:有123版本,目前都用"3"
-一个service代表一个container,这个container可以从dockerhub的image来创建,或者从本地dockerfilebuild的image来创建
-service的启动类似docker run,可以指定network和volume,所有可以给servier指定network和volume

healthcheck:
    test: ["CMD", "ping", "-c1", "-t1", "portainer"]  # 执行命令
    interval: 30s    # 等待时间
    timeout: 10s     # 延迟时间
    retries: 3		 # 尝试次数 

3 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 restart [容器的名称]  # 重启
docker-compose ps    # 正在运行的容器
docker-compose images # docker-compose管理的容器
docker-compose exec [参数] [service] [CMD] # 进入容器
docker-compose top   # 查看容器进程:
docker-compose pause  # 暂停运行
docker-compose unpause  # 恢复运行

docker-compose exec yml文件中写的service /bin/bash  # 进入到容器内

在这里插入图片描述

3 docker-compose案例

services:
  db:
    image: mysql:5.7
    volumes:
      - "db-data:/var/lib/mysql"
    networks:
      - my-bridge
# 等同于
# docker run -d --network my-bridge -v db-data"/var/lib/mysql mysql:5.7

三 Docker Compose 部署应用,水平扩展

部署flask redis

1 创建Dockerfile
vim Dockerfile

FROM python:3.6
COPY . /app
WORKDIR /app
RUN pip install flask redis
EXPOSE 5000
CMD [ "python", "app.py" ]

2 创建docker-compose文件
vim docker-compose.yml

version: "3"
services:
  redis:
    image: redis
  web:
    build:
      context: .
      dockerfile: Dockerfile
    ports:
      - 8080:5000
    environment:
      REDIS_HOST: redis
        
3 创建app.py
vim 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)
    
4 启动--运行
docker-compose up

docker-compose水平扩展

flask_redis项目扩展成三个

1. 删除docker-compose.yml中的port
2. 在yaml文件中加上一个负载均衡器HAProxy
3. Dockerfile文件不需要改
# docker-compose.yml

version: "3"

services:

  redis:
    image: redis

  web:
    build:
      context: .
      dockerfile: Dockerfile
    environment:
      REDIS_HOST: redis

  lb:
    image: dockercloud/haproxy
    links:
      - web
    ports:
      - 8080:80
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock 
             
# 把web扩展为3个,通过参数增加或减少启动的容器数
docker-compose up --scale web=3 -d

四 docker-compose可视化工具安装

方式一:

docker run -d -p 9000:9000 --restart always -v /var/run/docker.sock:/var/run/docker.sock -v /opt/portainer:/data portainer/portainer -H unix:///var/run/docker.sock

方式二:

version: '3.0'
services:
  portainer:
    image: portainer/portainer-ce
    ports:
    - "8001:8000"
    - "9001:9000"
    container_name: portainer
    networks:
      - "portainer"
    volumes:
    - "/var/run/docker.sock:/var/run/docker.sock"
    - "/root/docker-compose/portainer_data:/data"
    healthcheck:
      test: ["CMD", "ping", "-c1", "-t1", "portainer"]
      interval: 30s
      timeout: 10s
      retries: 3

networks:
  portainer:
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

go&Python

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值