Docker Compose 简介
Compose 是 docker 提供的一个命令行工具,用来定义和运行由多个容器组成的应用。
使用 compose,我们可以通过 YAML 文件声明式的定义应用程序的各个服务,并由单个命令完成应用的创建和启动。
Compose 的使用方式非常简单,基本上就是下面的三板斧:
- 定义 Dockerfile
- 定义 docker-compose.yml
- 运行 docker-compose up
其实 compose 提供的命令可以管理应用的整个生命周期:
- Start, stop, rebuild services
- 查看运行中 service 的状态
- 输出运行中 service 的日志
- 在 service 中执行一次性的命令
本文我们通过一个简单的 demo 来介绍 Docker Compose 的基本用法。说明:本文的演示环境为 ubuntu 16.04。本文的演示代码可以从 github 上下载。
安装 Docker Compose
安装 Docker Compose 前请先在本地安装 Docker。
Docker Compose 的安装十分简单,在 ubuntu 中直接把可执行文件下载到本地就可以了。
$ sudo curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-$(uname -s)-$(uname -m) -o /usr/local/bin/docker-compose
$ sudo chmod +x /usr/local/bin/docker-compose
其中 1.22.0 是最新的版本。当然 Docker Compose 是个开源项目,你可以选择安装不同的版本,或者是自行编译。下图为笔者安装之后显示的版本信息:

注意,默认的安装并不包括命令补全功能,也就是说像 docker-compose restart 这样的命令,你输入 docker-compose re 后按 tab 键是无法自动补全的。想要这个功能还需要额外的安装,以 Bash 为例,执行下面的命令:
$ sudo curl -L https://raw.githubusercontent.com/docker/compose/1.22.0/contrib/completion/bash/docker-compose -o /etc/bash_completion.d/docker-compose
然后重新登录 Bash,就可以通过 tab 键自动补全命令了!
创建演示 demo
下面的示例来自 docker 官网,就是一个简单的 Flask 网页应用,后端使用 redis 存储数据,其 web server 的代码如下(可以从这里下载到本文中的代码):
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)
if __name__ == "__main__":
app.run(host="0.0.0.0", debug=True)
代码非常简单,就是对请求计数并显示给用户。为了增加健壮性,在访问 redis 时做了一点处理:尝试访问 5 次再报错。把上面的代码保存到文件 app.py 中。
要运行上面的代码,需要在环境中安装 flask 和 redis 包。创建 requirements.txt 文件,编辑其内容为:
flask
redis
创建一个保存项目文件的目录,比如 composecounter,把 app.py 和 requirements.txt 文件都放进去。
创建 Dockerfile 文件
接下来我们需要把上面的应用打包到容器镜像中。在 composecounter 目录下创建 Dockerfile 文件:
FROM python:3.4-alpine
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]
上面代码的含义为:
- 使用 python:3.4-alpine 作为基础镜像
- 把当前目录添加到镜像中的 /code 目录
- 设置容器中的工作目录为 /code
- 安装 requirements.txt 文件中指定的依赖包
- 把容器启动时的默认命令设置为 python app.py
创建 compose 配置文件
终于来到本文的重点了!我们需要创建 Docker Compose 的配置文件来定义我们的应用。
YAML 是一个可读性高,用来表达数据序列的格式。Docker Compose 使用 YAML 格式的文件作为配置文件。
在 composecounter 目录中创建 docker-compose.yml 文件,其内容如下:
version: ''
services:
web:
build: .
ports:
- "5000:5000"
redis:
image: "redis:alpine"
第一行的 version: '3' 表示当前的配置文件使用的语法版本。
services 中的内容指明该应用一共定义了多少个服务(容器镜像)。在运行时,一个服务是指从该镜像启动的一个或多个容器。
在我们的示例中一共需要两个容器镜像。web 服务由我们自己通过 build . 命令构建,映射的端口是 flask web server 默认的 5000 端口。
redis 服务则直接使用官方的镜像。
构建并运行示例程序
在 composecounter 目录下执行命令:
$ docker-compose up
跳过那些繁琐的输出,我们直接访问本机的 5000 端口:

一个 web 应用程序运行起来了,并且输出了我们访问服务器端的次数,看起来还不错!
如果要让容器安静的运行在后台,加上 -d 选项就可以了:
$ docker-compose up -d
背后的事情
分析 docker-compose up 命令的输出可以看清事情的真相,但是日志过于繁琐,我们只说重点:
- 创建名称为 composecounter_default 的网络
- 使用 Dockerfile 构建 composecounter_web 镜像
- 创建容器 composecounter_redis_1 和 composecounter_web_1 并加入相同的网络
如果你手动去执行这些操作还是挺很繁琐的,现在一个命令就搞定了,还可以把相关的代码和配置统统的用版本管理工具管理起来。
总结
虽然示例程序能够运行起来了,但我们只是来到了一个新的起点。Docker Compose 被设计来管理应用的整个生命周期,我们也可以用它来极大的提高工作效率。笔者将在接下来的文章中介绍更多 Docker Compose 相关的内容。
参考:
Get started with Docker Compose
Docker Compose 简介的更多相关文章
- 25.docker compose 简介 和 docker-compose.yml 参数介绍
1. docker compose概念 文档 https://docs.docker.com/compose/compose-file/compose-versioning 一个基于 docker ...
- Docker & ASP.NET Core (5):Docker Compose
第一篇:把代码连接到容器 第二篇:定制Docker镜像 第三篇:发布镜像 第四篇:容器间的连接 Docker Compose简介 Compose是一个用来定义和运行多容器Docker应用的工具.使用C ...
- Docker 核心技术之Docker Compose
Docker Compose 简介 Docker Compose是什么? Docker Compose是一个能一次性定义和管理多个Docker容器的工具. 详细地说: Compose中定义和启动的每一 ...
- Docker Compose 之进阶篇
笔者在前文<Docker Compose 简介>和<Dcoker Compose 原理>两篇文章中分别介绍了 docker compose 的基本概念以及实现原理.本文我们将继 ...
- Docker Compose 原理
Docker 的优势非常明显,尤其是对于开发者来说,它提供了一种全新的软件发布机制.也就是说使用 docker 镜像作为软件产品的载体,使用 docker 容器提供独立的软件运行上下文环境,使用 do ...
- 通过 Docker Compose 组合 ASP NET Core 和 SQL Server
目录 Docker Compose 简介 安装 WebApi 项目 创建项目 编写Dockfile Web MVC 项目 创建项目 编写Dockfile 编写 docker-compose.yml文件 ...
- 1.Docker Compose
一.Docker Compose 简介 概述 Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排.从功能上看,跟 OpenStack 中的 Heat 十 ...
- 【Docker Compose】简介与安装
1.简介 Compose 是一个用户定义和运行多个容器的 Docker 应用程序.在 Compose 中你可以使用 YAML 文件来配置你的应用服务.然后,只需要一个简单的命令,就可以创建并启动你配置 ...
- Docker Compose安装以及入门
Docker Compose 是 Docker 官方编排(Orchestration)项目之一,负责快速在集群中部署分布式应用. Compose 简介 Compose 项目是 Docker 官方的开源 ...
随机推荐
- mac效率工具
前言:在命令行中切换目录是最常用的操作,我相信一遍又一遍重复“cd ls cd ls cd ls ……”绝对会让你抓狂. 记录一下,方便下次系统重装,哈哈 一. oh-my-zsh mac 预装了 z ...
- Egret获取和显示时间,年,月,日,时分秒
let now = new Date(); this.nowYear = now.getFullYear(); this.nowMonth = now.getMonth() + 1; let noww ...
- 2分钟读懂大数据框架Hadoop和Spark的异同
转自:https://www.cnblogs.com/reed/p/7730313.html 谈到大数据,相信大家对Hadoop和Apache Spark这两个名字并不陌生.但我们往往对它们的理解只是 ...
- SSIS - 10.执行过程任务
一.创建批处理文件 在SSIS包中,执行过程任务可以用来运行应用程序或批处理文件.它执行时用到的输入.输出和参数可以在任务编辑器中进行设置. 在使用执行过程任务之前,我们需要先创建一个批处理文件,实现 ...
- 别以为真懂Openstack: 虚拟机创建的50个步骤和100个知识点(1)
还是先上图吧,无图无真相 别以为真懂Openstack!先别着急骂我,我也没有说我真懂Openstack 我其实很想弄懂Openstack,然而从哪里下手呢?作为程序员,第一个想法当然是代码,Code ...
- 算法与数据结构(三) 二叉树的遍历及其线索化(Swift版)
前面两篇博客介绍了线性表的顺序存储与链式存储以及对应的操作,并且还聊了栈与队列的相关内容.本篇博客我们就继续聊数据结构的相关东西,并且所涉及的相关Demo依然使用面向对象语言Swift来表示.本篇博客 ...
- 【开源项目】电视盒子好用又强大的APP: TVRemoteIME
TVRemoteIME 电视盒子的远程输入法应用,可跨屏远程输入.跨屏远程控制盒子.远程文件管理.HTTP/RTMP/MMS网络视频直播.ED2K/种子文件的视频文件边下边播 应用的诞生 自从家里有电 ...
- Java软件工程师面试常见问题集锦之一
1.面向对象的特征有哪些方面 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节.抽象 ...
- Kali学习笔记41:SQL手工注入(3)
前两篇文章都是基于目标系统允许union,order by语句 并且可以读取infomation_schema元数据库 如果遇到的是安全方面做得很好的应用,进行了权限限制,那么我们有什么办法呢? 猜测 ...
- [Swift]LeetCode455. 分发饼干 | Assign Cookies
Assume you are an awesome parent and want to give your children some cookies. But, you should give e ...