打赏
Fork me on GitHub

1.Docker Compose

一、Docker Compose 简介

概述

Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排。从功能上看,跟 OpenStack 中的 Heat 十分类似。

其代码目前在 https://github.com/docker/compose 上开源。

Compose 定位是 「定义和运行多个 Docker 容器的应用(Defining and running multi-container Docker applications)」,其前身是开源项目 Fig。

我们知道使用一个 Dockerfile 模板文件,可以让用户很方便的定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个 Web 项目,除了 Web 服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。

Compose 恰好满足了这样的需求。它允许用户通过一个单独的 docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(Project)。Compose 中有两个重要的概念:

  • 服务 (Service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
  • 项目 (Project):由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml 文件中定义。

Compose 的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。Compose 项目由 Python 编写,实现上调用了 Docker 服务提供的 API 来对容器进行管理。因此,只要所操作的平台支持 Docker API,就可以在其上利用 Compose 来进行编排管理。

安装 Docker Compose

Compose 支持 Linux、macOS、Windows 10 三大平台。在 Linux 上的也安装十分简单,从 官方 GitHub Release 处直接下载编译好的二进制文件即可。

  1. curl -L https://github.com/docker/compose/releases/download/1.24.0/docker-compose-`uname -s`-`uname -m` /usr/local/bin/docker-compose
  2. chmod +/usr/local/bin/docker-compose

验证安装是否成功

  1. docker-compose version
  2. # 输出如下
  3. docker-compose version 1.24.0, build 0aa59064
  4. docker-py version3.7.2
  5. CPython version3.6.8
  6. OpenSSL versionOpenSSL 1.1.0j 20 Nov 2018

二、Docker Compose 使用

术语

首先介绍几个术语。

  • 服务 (Service):一个应用容器,实际上可以运行多个相同镜像的实例。
  • 项目 (Project):由一组关联的应用容器组成的一个完整业务单元。

可见,一个项目可以由多个服务(容器)关联而成,Compose 面向项目进行管理。

场景

最常见的项目是 Web 网站,该项目应该包含 Web 应用和缓存。下面我们用 Python 来建立一个能够记录页面访问次数的 Web 网站。

Python 应用

新建文件夹,在该目录中编写 app.py 文件

  1. from flask import Flask
  2. from redis import Redis
  3. app Flask(__name__)
  4. redis Redis(host='redis', port=6379)
  5. @app.route('/')
  6. def hello():
  7. count = redis.incr('hits')
  8. return 'Hello World! 该页面已被访问 {} 次。\n'.format(count)
  9. if __name__ == "__main__":
  10. app.run(host="0.0.0.0", debug=True)

Dockerfile

编写 Dockerfile 文件,内容为

  1. FROM python:3.6-alpine
  2. ADD /code
  3. WORKDIR /code
  4. RUN pip install redis flask
  5. CMD ["python""app.py"]

Docker Compose 模板

编写 docker-compose.yml 文件,这个是 Compose 使用的主模板文件。

  1. version'3'
  2. services:
  3. web:
  4. build.
  5. ports:
  6. "5000:5000"
  7. redis:
  8. image"redis:alpine"

运行 Compose 项目

  1. docker-compose up -d

此时访问本地 5000 端口,每次刷新页面,计数就会加 1。

扩展阅读

YAML 配置文件语言

YAML 是专门用来写配置文件的语言,非常简洁和强大,远比 JSON 格式方便。YAML 语言的设计目标,就是方便人类读写。它实质上是一种通用的数据串行化格式。它的基本语法规则如下:

  • 大小写敏感
  • 使用缩进表示层级关系
  • 缩进时不允许使用 TAB 键,只允许使用空格。
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可

# 表示注释,从这个字符一直到行尾,都会被解析器忽略。YAML 支持的数据结构有三种:

  • 对象: 键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
  • 数组: 一组按次序排列的值,又称为序列(sequence) / 列表(list)
  • 纯量(scalars): 单个的、不可再分的值

YAML 对象

对象的一组键值对,使用冒号结构表示

  1. animal: pets

YAML 数组

一组连词线开头的行,构成一个数组

  1. Cat
  2. Dog
  3. Goldfish

数据结构的子成员是一个数组,则可以在该项下面缩进一个空格

  1. Array
  2. Cat
  3. Dog
  4. Goldfish

YAML 复合结构

对象和数组可以结合使用,形成复合结构

  1. languages:
  2. Ruby
  3. Perl
  4. Python
  5. websites:
  6. YAML: yaml.org
  7. Ruby: ruby-lang.org
  8. Python: python.org
  9. Perluse.perl.org

YAML 纯量

纯量是最基本的、不可再分的值。以下数据类型都属于 JavaScript 的纯量

  • 字符串
  • 布尔值
  • 整数
  • 浮点数
  • Null
  • 时间
  • 日期

修改 IP 和 DNS

课程演示会采用多虚拟机模拟分布式场景,为防止 IP 冲突,无法联网等问题,需要预先设置好主机名、IP、DNS 配置

修改主机名

  • 修改 cloud.cfg 防止重启后主机名还原
  1. vi /etc/cloud/cloud.cfg
  2. # 该配置默认为 false,修改为 true 即可
  3. preserve_hostname: true
  • 修改主机名
  1. # 修改主机名
  2. hostnamectl set-hostname deployment
  3. # 配置 hosts
  4. cat >> /etc/hosts << EOF
  5. 192.168.141.130 deployment
  6. EOF

修改 IP

编辑 vi /etc/netplan/50-cloud-init.yaml 配置文件,修改内容如下

  1. network:
  2. ethernets:
  3. ens33:
  4. addresses[192.168.141.130/24]
  5. gateway4192.168.141.2
  6. nameservers:
  7. addresses[192.168.141.2]
  8. version2

使用 netplan apply 命令让配置生效

修改 DNS

  1. # 取消 DNS 行注释,并增加 DNS 配置如:114.114.114.114,修改后重启下计算机
  2. vi /etc/systemd/resolved.conf
posted @ 2019-12-04 10:15  l-coil  阅读(178)  评论(0编辑  收藏  举报