1.安装了docker-compose,现在我们要使用docker-compose来运行容器栈。这个地方会有两个容器,一个容器中使用Flask搭建的简单应用,另一个容器是Redis,Flash会向redis写入数据。因此设计到容器之间的通信。之前我们讲到了,容器之间通信可以使用--link,也可以使用docker networking的方式,那这节课,我们讲解使用docker-compose来更加方便的管理多容器栈。

2.创建composeapp目录

$ cd /home/xm6f/dev/
$ mkdir composeapp
$ cd composeapp
$ touch Dockerfile

Dockerfile中保存用于构建Docker镜像的指令;还要创建app.py文件,这个文件中编写Flask代码。

app.py文件内容:

#!/usr/bin/env python2
# -*- coding: utf- -*-
# 导入 Flask 和 Redis 模块
from flask import Flask
from redis import Redis
import os
# 创建 Flask app
app = Flask(__name__)
# 通过 host 连接到 Redis
redis = Redis(host="redis",port=)
# 指定访问路径
@app.route('/')
def hi():
redis.incr("ping")
return 'hi , you have ping {0} times'.format(redis.get('ping'))
if __name__ == '__main__':
app.run(host="0.0.0.0",debug=True)

创建requirements.txt文件,里面放置程序依赖名称:

flask
redis

创建Dockerfile文件,用于构建镜像:

# 指定基镜像为 python2.
FROM python
MAINTAINER ruthless @qq.com
ADD . /composeapp
WORKDIR /composeapp
RUN pip install -r requirements.txt
$ ls
app.py Dockerfile requirements.txt

使用docker build -t composeapp . 指令创建composeapp镜像。

$ docker build -t composeapp .
$ docker images

redis镜像我们就不自己制作了,直接使用Docker Hub上面默认的redis即可,获取redis镜像如下:

$ docker search redis
$ docker pull redis

3.编写docker-compose.yml文件
应用镜像都构建好了之后,就可以配置compose来创建服务了,compose通过一个约定格式的配置文件配置要启动的服务,每个服务可以选择配置适当的属性,这些属性和docker run命令需要的参数类似。所有的服务和属性都定义在YAML(一种标记语言)文件中,定义好了之后执行docker-compose up命令,compose服务将会根据docker-compose.yml文件启动服务。

创建docker-compose.yml文件
$ touch docker-compose.yml

docker-compose.yml文件中包括一个或者多个要运行的docker容器指令。

web: ##启动容器的名字
image: composeapp ##从哪个镜像启动
command: python app.py ##启动运行之后,执行哪些命令
ports:
- "5000:5000"
volumes:
- .:/composeapp ##当前目录挂载到composeapp目录
links:
- redis redis:
image: redis

在docker-compose.yml文件中,
image其实也可以指定为Dockerfile文件的路径,
通过command指定服务启动时要执行的命令,类似于Dockerfile中的CMD指令,
使用ports指定端口映射,
使用volumes指定卷,
使用links指定要连接到哪些服务。
这个地方是将redis和web服务进行性连接,类似于docker run命令里面的--link选项。

编辑好docker-compose.yml文件之后,使用docker-compose up命令在docker-compose.yml所在目录执行。compose即上传并开始解析定义在docker-compose.yml文件中的指令。

从运行打印的日志可以看到,compose创建了composeapp_redis_1、composeapp_web_1两个服务,这两个服务的名字是docker-compose.yml所在目录的名字加上docker-compose.yml文件中指定的名字再加上一个数字组成,其目的是保证服务的唯一性。

4.可以使用-d选项,以守护方式运行compose
$ docker-compose up -d

5.查看日志信息
$ docker-compose ps
$ docker-compose logs web
$ docker-compose logs redis

6.使用docker-compose port web 5000 查看web服务5000端口映射情况
$ docker-compose port web 5000
0.0.0.0:5000

注意:操作docker-compose命令要跟docker-compose.yml在同一目录,否则无法操作。

7.网页访问web计数器

刷新浏览器,times会依次递增

构建Docker Compose服务堆栈的更多相关文章

  1. Docker | 第七章:Docker Compose服务编排介绍及使用

    前言 前面章节,我们学习了如何构建自己的镜像文件,如何保存自己的镜像文件.大多都是一个镜像启动.当一个系统需要多个子系统进行配合时,若每个子系统也就是镜像需要一个个手动启动和停止的话,那估计实施人员也 ...

  2. docker compose 服务启动顺序控制

    概要 docker-compose 可以方便组合多个 docker 容器服务, 但是, 当容器服务之间存在依赖关系时, docker-compose 并不能保证服务的启动顺序. docker-comp ...

  3. docker和docker compose安装使用、入门进阶案例

    一.前言 现在可谓是容器化的时代,云原生的袭来,导致go的崛起,作为一名java开发,现在慌得一批.作为知识储备,小编也是一直学关于docker的东西,还有一些持续继承jenkins. 提到docke ...

  4. Docker 0x13: Docker 构建集群/服务/Compose/分布式服务栈

    目录 Docker 构建集群/服务/Compose/分布式服务栈 集群 初始化集群服务 安装docker-machine 管理节点和工作节点 docker集群构建完成 集群中部署应用 集群服务访问特性 ...

  5. Docker之Compose服务编排

    Compose是Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 说明:Comp ...

  6. (转)Docker之Compose服务编排

    转自:https://www.cnblogs.com/52fhy/p/5991344.html Compose是Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过 ...

  7. [phvia/dkc] Docker Compose 快速构建(LNMP+Node)运行环境

    快速构建(LNMP+Node)运行环境. dkc 在此作为 docker-compose 的缩写,你可以理解为 alias dkc=docker-compose 准备 安装 docker 选择1) 从 ...

  8. docker从零开始(三)服务初体验docker compose

    决条件 安装Docker 1.13或更高版本. 获取Docker Compose.在适用于Mac的Docker和适用于Windows的Docker上,它已预先安装,因此您可以随意使用.在Linux系统 ...

  9. 使用Docker Compose编排微服务

    一般微服务架构会包含若干个微服务,而每个微服务可以有多个实例,如果每个微服务都有手动启停,那么效率就很低.维护量比较大. 所以我们可以使用Docker Compose来轻松.高效地管理容器. 一.安装 ...

随机推荐

  1. spring mvc controller中的参数验证机制(二)

    这里我们介绍以下自定义的校验器的简单的使用示例 一.包结构和主要文件 二.代码 1.自定义注解文件MyConstraint package com.knyel.validator; import ja ...

  2. 2019.02.11 bzoj3165: [Heoi2013]Segment(线段树)

    传送门 题意简述:要求支持两种操作: 插入一条线段. 询问与直线x=kx=kx=k相交的线段中,交点最靠上的线段的编号. 思路: 直接上李超线段树即可. 代码: #include<bits/st ...

  3. POJ2516K次费用流建图

    Description: N个订单(每个订单订K种商品),M个供应商(每个供应商供应K种商品),K种商品,后N行,表示每一个订单的详细信息,后M行表示每个供应商供应的详细信息,后K 个N * M的矩阵 ...

  4. PMP:7.项目成本管理

    内容中包含 base64string 图片造成字符过多,拒绝显示

  5. 基于Docker+Jenkins+Gitlab搭建持续集成环境

    随着DevOps理念和敏捷理念的发展,我们希望通过自动化技术,加快项目的迭代.尤其是当使用微服务方案后,面临在大量的项目构建和部署工作,借助于jenkins的持续集成,可以快速把应用打包成docker ...

  6. [Project] SpellCorrect源码详解

    该Project原来的应用场景是对电商网站中输入一个错误的商品名称进行智能纠错,比如iphoae纠错为iphone.以下介绍的这个版本对其作了简化,项目源代码地址参见我的github:https:// ...

  7. B树之C语言实现(包含查找、删除、插入)

    B树的定义 一棵m阶B树(Balanced Tree of order m),或为空树,或为满足下列特性对的m叉树. 树中每个结点最多含有m棵子树. 若根结点不是叶子结点,则至少有2个子树. 除根结点 ...

  8. Adobe reader multiple languages pack

    用户打开客户发过来的PDF文档,显示不正常,这是电脑的Adobe Reader缺少相关的字体. 可以从下面地址下载相对版本的字体包安装:http://supportdownloads.adobe.co ...

  9. Vue自定义指令,ref ,sync,slot

    一.自定义指令 vue中可以自己设置指令,通过directive来实现,有2种创建方式,一种是局部创建,一种是全局创建. 第一种:局部创建 如果想注册局部指令,组件中也接受一个 directives  ...

  10. Python队列及在微信机器人中的应用

    本文来源于i春秋学院,未经允许严禁转载. 最近打算更新微信机器人,发现机器人的作者将代码改进了很多,但去掉了sqlite数据库,需要自己根据需求设计数据库,跟作者沟通得到的建议是为了防止消息并发导致数 ...