Docker(四):Docker三剑客之Docker Compose_hello world! i have been seen 1 times.-程序员宅基地

技术标签: 集装箱部署  学习笔记  docker  

前两篇文章我们介绍了Dockerfile的使用Docker(二):Dockerfile使用介绍,我们知道使用一个Dockerfile模板文件可以定义一个单独的应用容器,如果需要定义多个容器就需要服务编排。服务编排有很多种技术方案,今天给大家介绍Docker官方产品Docker Compose。

Dockerfile可以让用户管理一个单独的应用容器;而Compose则允许用户在一个模板(YAML格式)中定义一组相关联的应用容器(被称为一个项目,即项目),例如一个Web服务容器再加上后端的数据库服务容器等。

Docker Compose介绍

通过Docker-Compose用户可以很容易地用一个配置文件定义一个多容器的应用,然后使用一条指令安装这个应用的所有依赖,完成构建.Docker-Compose解决了容器与容器之间如何管理编排的问题。

Docker Compose工作原理图

撰写中有两个重要的概念:

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

一个项目可以由多个服务(容器)关联而成,Compose面向项目进行管理,通过子命令对项目中的一组容器进行便捷地生命周期管理。

Compose项目由Python编写,实现上调用了Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose进行编排管理。

Docker撰写安装

Docker Compose是Docker的独立产品,因此需要安装Docker之后在单独安装Docker Compose。

方法一:

#下载
sudo curl -L https://github.com/docker/compose/releases/download/1.20.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
#安装
chmod +x /usr/local/bin/docker-compose
#查看版本
docker-compose version

方法二:

#安装pip
yum -y install epel-release
yum -y install python-pip
#确认版本
pip --version
#更新pip
pip install --upgrade pip
#安装docker-compose
pip install docker-compose 
#查看版本
docker-compose version

推荐使用方法一进行安装,安装成功后输入docker-compose version会返回docker-compose的版本信息,如下:

[root@localhost ~]# docker-compose version
docker-compose version 1.19.0, build 9e633ef
docker-py version: 2.7.0
CPython version: 2.7.13
OpenSSL version: OpenSSL 1.0.1t  3 May 2016

出现以上信息,表明docker-compose安装成功

安装补全工具(可选)

为了方便我们输入命令,也可以安装Docker的补全提示工具帮忙我们快速输入命令

#安装
yum install bash-completion

#下载docker-compose脚本
curl -L https://raw.githubusercontent.com/docker/compose/$(docker-compose version --short)/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose

快速上手

没有什么比来一个小例子练练手更好的学习方法了,我们以官网上的简单示例来看看docker compose的使用方法。

我们设计这么一个场景,使用Python启动一个Web服务,输出一个hello()方法,每次访问的时候在Redis缓存中进行计数,并且将统计的结果打印到页面中。

第一步,创建Python服务

创建项目路径:

mkdir composetest
cd composetest

在目录下创建app.py文件

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 使用了容器内的网络默认端口是6379。这段 Python 程序的内容就是,启动后连接 Redis 并且输出 hello()方法,当每次访问的时候累计访问次数并且将结果放回到页面。

在同目录下创建requirements.txt文件,添加项目依赖的python包:

flask
redis

Flask 是 Python 中一个微型的 Web 开发框架。

第二步,创建 Dockerfile

我们来写一个 Dockerfile 来定义 Docker 镜像,此镜像包含了 Python 的依赖包和 Python 环境。

同样在此目录下,我们创建一个 Dockerfile 文件。

FROM python:3.4-alpine
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]

这段代码表示:

  • 使用基础镜像 Python 3.4
  • 将当前目录映射到镜像/code目录下
  • 设置工作目录为 /code
  • 安装 Python 依赖包
  • 启动 app.py 程序

第三步,使用 Compose 文件定义一个服务

在当期目录下,我们创建一个 docker-compose.yml 文件,内容如下:

version: '2'
services:
  web:
    build: .
    ports:
     - "5000:5000"
  redis:
    image: "redis:alpine"

这个 Compose 文件定义了两个服务, 一个 Pyhon Web 服务和 redis 服务。

  • Pyhon Web 服务:使用 Dockerfile 构建了当前镜像。将 Web 容器内部的5000端口映射到 host 的5000端口;并将 Web 容器与 redis 容器连接。
  • redis服务:该容器直接由官方的 redis 镜像创建。

第四步,使用 Compose 编译启动应用

使用命令docker-compose up启动

version: '2'
services:
  web:
    build: .
    command: python app.py
    ports:
     - "5000:5000"
    volumes:
     - .:/code
  redis:
    image: "redis:alpine"

启动成功之后,在浏览器访问:http://ipaddress:5000/ ,返回如下:

Hello World! I have been seen 1 times.

刷新再次访问返回

Hello World! I have been seen 2 times.

不断的刷新数字会不断的增长。

Docker Compose 常用命令

使用docker-compose up -d在后台启动服务

[root@localhost composetest]# docker-compose up -d
Starting composetest_web_1 ... 
Starting composetest_web_1 ... done

使用docker-compose ps命令查看启动的服务

[root@localhost composetest]# docker-compose ps
       Name                      Command               State           Ports         
-------------------------------------------------------------------------------------
composetest_redis_1   docker-entrypoint.sh redis ...   Up      6379/tcp              
composetest_web_1     python app.py                    Up      0.0.0.0:5000->5000/tcp

使用docker-compose stop停止服务。

[root@localhost composetest]# docker-compose stop
Stopping composetest_web_1   ... done
Stopping composetest_redis_1 ... done

其它常用命令

#查看帮助
docker-compose -h

# -f  指定使用的 Compose 模板文件,默认为 docker-compose.yml,可以多次指定。
docker-compose -f docker-compose.yml up -d 

#启动所有容器,-d 将会在后台启动并运行所有的容器
docker-compose up -d

#停用移除所有容器以及网络相关
docker-compose down

#查看服务容器的输出
docker-compose logs

#列出项目中目前的所有容器
docker-compose ps

#构建(重新构建)项目中的服务容器。服务容器一旦构建后,将会带上一个标记名,例如对于 web 项目中的一个 db 容器,可能是 web_db。可以随时在项目目录下运行 docker-compose build 来重新构建服务
docker-compose build

#拉取服务依赖的镜像
docker-compose pull

#重启项目中的服务
docker-compose restart

#删除所有(停止状态的)服务容器。推荐先执行 docker-compose stop 命令来停止容器。
docker-compose rm 

#在指定服务上执行一个命令。
docker-compose run ubuntu ping docker.com

#设置指定服务运行的容器个数。通过 service=num 的参数来设置数量
docker-compose scale web=3 db=2

#启动已经存在的服务容器。
docker-compose start

#停止已经处于运行状态的容器,但不删除它。通过 docker-compose start 可以再次启动这些容器。
docker-compose stop

参考

开始使用Docker Compose
使用Docker-Compose编排容器

(转载本站文章请注明作者和出处纯洁的微笑-ityouknow

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_41133233/article/details/82922787

智能推荐

【Java程序设计】【C01133】基于(JavaWeb)SSM的选课排课系统(含论文+PPT)-程序员宅基地

文章浏览阅读261次,点赞15次,收藏4次。运行环境:推荐jdk1.8;开发工具:eclipse以及idea(推荐)、maven;操作系统:windows 10 8G内存以上(其他windows以及macOS支持,但不推荐);浏览器:Firefox(推荐)、Google Chrome(推荐)、Edge;数据库:MySQL8.0(推荐)及其他版本(支持,但容易异常尤其MySQL5.7(不含)以下版本);数据库可视化工具:Navicat Premium 15(推荐)以及其他Navicat版本是否maven项目:是。

node.js 使用 UglifyJS2 高效率压缩 javascript 文件-程序员宅基地

文章浏览阅读266次。UglifyJS2 这个工具使用很长时间了,但之前都是在 gulp 自动构建 时用到了 UglifyJS 算法进行压缩. 最近玩了一下 UglifyJS2 ,做了一个 在线压缩javascript工具 欢迎点击玩耍.为什么要压缩 javascript因为每个人开发者的书写习惯,定义参数习惯,已经使用习惯都不一样. 所以相同的功能出自不同开发者代码各异.这里牵扯到一个代码所占..._nodejs uglify

ORACLE-SQL(一)-程序员宅基地

文章浏览阅读77次。 迁移时间:2017年6月1日10:02:43CreateTime--2017年6月1日09:59:30Author:Marydon一、SQL语句  (一)基础篇    1.1.1 where 子句      1.1.1.1 where后面可以跟多个条件表达式,表达式之间用and或or连接--查询除去emp表前5条的员工信息(即rownum>5) ..._查询部门编号是10,20,50的人的员工编号

mac下安装thrift踩坑_macm1安装thrift时,执行make报错make[4]: nothing to be done-程序员宅基地

文章浏览阅读1.3k次。今天在安装thrift的时候有种回到了当初刚开始学编程的那种状态,配个环境折腾老半天。本来就在idl里面改动了3行代码,想重新生成一下,确认了该项目之前使用thrift 0.10.0生成后,不得不将已经安装的thrift 0.12.0换掉。本来想用brew install thrift简单安装一下的,但是brew search thrift之后发现只有0.9.0版本的,于是不得不下载源码,手动..._macm1安装thrift时,执行make报错make[4]: nothing to be done for `all-am'xcode-

指定mysql jdbctype_MyBatis JdbcType 与Oracle、MySql数据类型对应关系说明-程序员宅基地

文章浏览阅读315次。1. Mybatis JdbcType与Oracle、MySql数据类型对应列表MybatisJdbcTypeOracleMySqlJdbcTypeARRAYJdbcTypeBIGINTBIGINTJdbcTypeBINARYJdbcTypeBITBITJdbcTypeBLOBBLOBBLOBJdbcTypeBOOLEANJdbcTypeCHARCHARCHARJdbcTypeCLOBCLOBCL..._oracle数据库的的text类型的字段,jdbctype是什么类型

Visual Studio Code 配置 C/C++ 运行环境 - 搭配 MinGW 完美 GNU 配置 Editor_gnu::pure visual studio-程序员宅基地

文章浏览阅读2k次,点赞7次,收藏26次。Visual Studio Code 配置 C/C++ 运行环境 - 搭配 MinGW 完美 GNU 配置前言简介MinGWMinGW 下载安装MinGW 系统环境配置Visual Studio CodeVisual Studio Code 安装以及其基本 C/C++ 插件安装Visual Studio Code C/C++ 环境配置功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入..._gnu::pure visual studio

随便推点

SoapUI接口测试实例(webservice接口)-程序员宅基地

文章浏览阅读745次。接口测试步骤注:以测试queryHistoryAccepts接口作举例。1、用户登录获取SessionKey实体信息注:由于大部分的接口都需要SessionKey实体的信息,因此测试那些接口都需要先调用用户登录接口,用于获取SessionKey实体下的信息。在接口显示窗口找到CommonServiceSoap11Binding下的CheckCallerPermision..._soaoui测试的接口 返回的raw信息 server是unknown

文心一言插件开发(第二篇-程序员宅基地

文章浏览阅读887次,点赞19次,收藏14次。name_for_human”,平台内全局唯一标识,后缀数字建议长且随机,更不容易重名冲突,这里改成了"单词本_TianJi"“name_for_model”,这里改成了"wordbook_TianJi"官网提供了一套示例demo文件。也可以把修改文件后的压缩包上传。回到文心一言,点击本地调试。,提取码: q7xa。

SAP CRM 创建销售订单时报错 - CRM_ORDER_MISC 020-程序员宅基地

文章浏览阅读387次。(2) 检查这篇 wiki 里介绍的步骤:https://wiki.scn.sap.com/wiki/display/CRM/Partner+conversion+error+in+sales+or+service+documents+CRM-BF-PD。这个朋友采取的解决方案就是将订单的 contact person 字段删除,再重新维护,然后错误就消失了。这是一个 CRM 系统和远端系统(ERP 系统?) 进行数据传输时出的问题。错误消息:复制文件时,系统 PRDCLNT800 中发生错误。

Leetcode 14. Longest Common Prefix-程序员宅基地

文章浏览阅读36次。https://leetcode.com/problems/longest-common-prefix/class Solution {public: string longestCommonPrefix(vector<string>& strs) { if(strs.empty()) return ""; string ans=st...

jenkins构建定时测试任务报错----ImportError: No module named 'unittest2'-程序员宅基地

文章浏览阅读1.3k次。直接执行脚本是没有问题,报如下错误:File “test_HTML_run_all.py”, line 4, in import unittest2ImportError: No module named ‘unittest2’_no module named 'unittest2

unity3D游戏开发四之创建基本游戏场景一_unity场景一个人游戏一般做多少个-程序员宅基地

文章浏览阅读1.8w次。Unity创建游戏的理念可以被jian'da_unity场景一个人游戏一般做多少个

推荐文章

热门文章

相关标签