前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >云原生时代必须具备的核心技能之Docker高级篇(DockerCompose-容器编排)

云原生时代必须具备的核心技能之Docker高级篇(DockerCompose-容器编排)

作者头像
用户4919348
发布2022-01-06 14:34:21
2670
发布2022-01-06 14:34:21
举报
文章被收录于专栏:波波烤鸭波波烤鸭
请添加图片描述
请添加图片描述

1 DockerCompose介绍

  Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。

一键启动所有的服务

DockerCompose的使用步骤

  • 创建对应的DockerFile文件
  • 创建yml文件,在yml文件中编排我们的服务
  • 通过docker-compose up命令 一键运行我们的容器

2 Compose安装

  官网地址:https://docs.docker.com/compose

代码语言:javascript
复制
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

速度比较慢的话使用下面的地址:

代码语言:javascript
复制
curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

修改文件夹权限

代码语言:javascript
复制
chmod +x /usr/local/bin/docker-compose

建立软连接

代码语言:javascript
复制
ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

校验是否安装成功

代码语言:javascript
复制
docker-compose --version

3 Compose初体验

  通过官方案例来演示:https://docs.docker.com/compose/gettingstarted/

  创建对应的目录

代码语言:javascript
复制
 mkdir composetest
 cd composetest

  创建Python文件 app.py

代码语言:javascript
复制
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)

  在同级目录下创建requirements.txt文件

代码语言:javascript
复制
flask
redis

  然后创建对应的Dockerfile文件

代码语言:javascript
复制
# syntax=docker/dockerfile:1
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
EXPOSE 5000
COPY . .
CMD ["flask", "run"]

  然后创建核心的 yml文件docker-compose.yml

代码语言:javascript
复制
version: "3.9"
services:
  web:
    build: .
    ports:
      - "5000:5000"
  redis:
    image: "redis:alpine"

  最终通过docker-compose up命令来启动容器

代码语言:javascript
复制
docker-compose up
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  启动时间比较久,耐心等待即可

  测试访问:

在这里插入图片描述
在这里插入图片描述

  如果要退出服务 Ctrl+c 或者 docker-compose down

4 Compose配置规则

  docker-compse.yml核心

  官网地址:https://docs.docker.com/compose/compose-file/compose-file-v3/

代码语言:javascript
复制
version: '' # 版本
servers:  # 服务
  服务1: web
     # 服务的配置
     build
     network
     images
  服务2: redis
  服务3:
  服务4:
  ...
# 其他配置 网络,全局的规则 数据卷
volumes:
configs:
networks:

5 Compose一键部署实战

5.1 一键部署WP博客

1> 创建my_wordpress目录

代码语言:javascript
复制
mkdir my_wordpress

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

代码语言:javascript
复制
version: "3.9"
    
services:
  db:
    image: mysql:5.7
    volumes:
      - db_data:/var/lib/mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: somewordpress
      MYSQL_DATABASE: wordpress
      MYSQL_USER: wordpress
      MYSQL_PASSWORD: wordpress
    
  wordpress:
    depends_on:
      - db
    image: wordpress:latest
    volumes:
      - wordpress_data:/var/www/html
    ports:
      - "8000:80"
    restart: always
    environment:
      WORDPRESS_DB_HOST: db:3306
      WORDPRESS_DB_USER: wordpress
      WORDPRESS_DB_PASSWORD: wordpress
      WORDPRESS_DB_NAME: wordpress
volumes:
  db_data: {}
  wordpress_data: {}

3>通过up命令启动

代码语言:javascript
复制
docker-compose up -d
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.2 部署一个SpringBoot项目

我们自己通过Java项目实现访问计数的功能

代码语言:javascript
复制
FROM java:8
COPY my-counter-views-0.0.1-SNAPSHOT.jar app.jar
EXPOSE 8080
CMD ["java","-jar","app.jar"]

yml

代码语言:javascript
复制
version: '3.9'
services:
  myapp:
    build: .
    image: myapp
    depends_on:
      - redis
    ports:
      - "8080:8080"
  redis:
    image: "library/redis:alpine"

6 Compose常见操作

(1)查看版本

​ docker-compose version

(2)根据yml创建service

​ docker-compose up

​ 指定yaml:docker-compose up -f xxx.yaml

​ 后台运行:docker-compose up -d

(3)查看启动成功的service

​ docker-compose ps

​ 也可以使用docker ps

(4)查看images

​ docker-compose images

(5)停止/启动service

​ docker-compose stop/start

(6)删除service[同时会删除掉network和volume]

​ docker-compose down

(7)进入到某个service

​ docker-compose exec redis sh

7 scale扩缩容

代码语言:javascript
复制
docker-compose up --scale web=5 -d
在这里插入图片描述
在这里插入图片描述

小结:docker-compose

工程–>服务–>容器

代码语言:javascript
复制
version:
services:
  服务1:
  服务2:
  服务3:
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-11-27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 DockerCompose介绍
  • 2 Compose安装
  • 3 Compose初体验
  • 4 Compose配置规则
  • 5 Compose一键部署实战
    • 5.1 一键部署WP博客
      • 5.2 部署一个SpringBoot项目
      • 6 Compose常见操作
      • 7 scale扩缩容
      相关产品与服务
      容器镜像服务
      容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档