构建Docker Compose服务堆栈

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-8 -*-
# 导入 Flask 和 Redis 模块
from flask import Flask
from redis import Redis
import os
# 创建 Flask app
app = Flask(__name__)
# 通过 host 连接到 Redis
redis = Redis(host="redis",port=6379)
# 指定访问路径
@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.7
FROM python
MAINTAINER ruthless 416501600@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会依次递增

原文地址:https://www.cnblogs.com/linjiqin/p/8831041.html

时间: 2024-08-29 23:58:34

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

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

前言 前面章节,我们学习了如何构建自己的镜像文件,如何保存自己的镜像文件.大多都是一个镜像启动.当一个系统需要多个子系统进行配合时,若每个子系统也就是镜像需要一个个手动启动和停止的话,那估计实施人员也会崩溃的,而且效率也很低,维护的量也就很大了.所以,本章节就来了解下,如何利用官方提供的Compose编排工具按一定的业务规则来合理的进行容器启停工作. Compose介绍 Compose安装 二进制文件直接安装 使用pip(Python包管理工具)安装 命令补齐 Compose常用命令 build

Docker Compose服务编排

一.Docker Compose: 服务编排技术:https://github.com/docker/compose/releases 二.安装:(Linux 64位系统) 1)请求安装包:curl -L https://github.com/docker/compose/releases/download/1.24.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose 2)改变权限:chmod +x /u

Docker学习 Part-07(Docker Compose 服务编排)

Docker Compose 一.安装Docker Compose # Compose目前已经完全支持Linux.Mac OS和Windows,在我们安装Compose之前,需要先安装Docker.下面我 们以编译好的二进制包方式安装在Linux系统中. curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/

有容云:实战总结之 利用Docker、Docker Compose &Rancher构建持续部署

前言: 本文由John Patterson . Chris Lunsford写于2016年4月4日,译者有容云张向波,转载请注明出处.(原文链接见文末) 作者John Patterson和Chris Lunsford 运营了一家提供运营和基础架构服务的公司,本文是他们给大家分享的内容:关于如何通过使用Docker.Docker-Compose和Rancher来实现容器部署落地. 我们想跟你一起从头开始体验整个过程,特别是之间遇到的一些痛点和所做的决策.目前,已经有许多的资源和工具可以与Docke

Docker之Compose服务编排

Compose是Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 说明:Compose是Fig的升级版,Fig已经不再维护.Compose向下兼容Fig,所有fig.yml只需要更名为docker-compose.yml即可被Compose使用. 服务编排工具使得Docker应用管理更为方便快捷. Compose网站:https://docs.docker.com/compos

(转)Docker之Compose服务编排

转自:https://www.cnblogs.com/52fhy/p/5991344.html Compose是Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 说明:Compose是Fig的升级版,Fig已经不再维护.Compose向下兼容Fig,所有fig.yml只需要更名为docker-compose.yml即可被Compose使用. 服务编排工具使得Docker应用管理

Docker Compose 1.18.0 之服务编排详解

一个使用Docker容器的应用,通常由多个容器组成.使用Docker Compose,不再需要使用shell脚本来启动容器.在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 服务编排工具使得Docker应用管理更为方便快捷. Docker Compose网站:https://docs.docke

docker compose项目构建

##docker compose安装1.安装epel源 yum install epel-releae -y 2.安装python-pip yum install -y python-pip 3.安装docker compose pip install docker-compose 4.查看docker compose docker-compose version docker compose项目构建 #新建项目文件夹并切换进入项目文件夹 [email protected]:~#mkdir xi

Docker Compose 部署Nginx服务实现负载均衡

Compose简介: Compose是Docker容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器,使用Docker Compose,不再需要使用shell脚本来启动容器.Compose通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用.docker-compose默认的模板文件是 docker-compose.yml,其中定义的每个服务都必须通过image 指令指定镜