`

【赵强老师】使用Docker Compose进行服务编排

阅读更多

一、什么是Docker Compose?

Docker Compose是一个用来定义和运行复杂应用的Docker工具。一个使用Docker容器的应用,通常由多个容器组成。使用Docker Compose不再需要使用shell脚本来启动容器,而使用服务编排的方式来管理容器。
Docker Compose 通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。

Docker Compose的核心是通过一个YAML文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义。

二、什么是YAML文件?

YAML (YML)的意思其实是:"Yet Another Markup Language"(仍是一种置标语言)的缩写。YAML的语法和其他高阶语言类似,并且可以简单表达清单、散列表,标量等资料形态。它使用空格缩排和大量依赖外观的特色,特别适合用来表达或编辑数据结构、各种设定档、倾印除错内容、文件大纲(例如:许多电子邮件标题格式和YAML非常接近)。可以是用 .yml 或 .yaml 作为文件扩展名。

三、部署Docker Compose

  • 官方文档:https://docs.docker.com/compose/install
  • 执行下面的语句进行安装
curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m)" \
-o /usr/local/bin/docker-compose

chmod +x /usr/local/bin/docker-compose
docker-compose --version

 

四、使用Docker Compose构建Python Web应用

这里,我们将使用两种不同的方式:手动部署和利用Docker Compose部署,来说明使用Docker Compose进行部署所带来的好处。

  • 首先,我们需要创建我们的应用程序,实现一个简单的计数器功能。这里我们需要创建三个文件:app.py、requirements.txt和Dockerfile,具体内容如下。
##app.py应用程序代码
from flask import Flask
from redis import Redis
import os
app = Flask(__name__)
redis = Redis(host='redis', port=6379)
 
@app.route('/')
def hello():
    redis.incr('hits')
    return 'Hello World! I have been seen %s times.' % redis.get('hits')
 
if __name__ == "__main__":
    app.run(host="0.0.0.0", debug=True)
	
-----------------------------------------	
##requirements.txt文件内容
flask
redis

-----------------------------------------	
##Dockerfile文件内容
FROM python:3.4-alpine
ADD . /code
WORKDIR /code
COPY app.py /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]
 
  • 手动部署应用程序
##由于应用程序中,需要redis的支持,首先启动一个Redis容器
docker run --name myredis -d -p 6379:6379 redis

##使用docker build编译Dockerfile
docker build -t myapplication .

##使用docker run命令启动应用程序,并使用--link参数连接到上面的redis容器中
docker run --name myapp_using_redis -p 5000:5000 --link myredis:redis -d myapplication
其中:--link参数中的:
myredis:是上面的启动的Redis容器
redis:是这个Redis的容器的别名(可以看成是HostName)

##通过网址http://192.168.15.133:5000访问应用程序
##刷新页面,计数器会自增。
 

  • 利用docker-compose快速部署Python开发环境

而事实上,我们可以使用更加简化的方式来定义我们的容器组合管理,使用Docker-compose来定义我们的容器组合关系。目录结构下,包含以下文件:

其中,docker-compose.yml文件内容如下:

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

执行docker-compose up来启动应用,访问应用程序:http://192.168.15.133:5000/

从这里例子中我们可以看到,通过Docker Compose的YAML配置文件,我们把两个相关的Service(web和redis)进行了服务编排,从而简化的应用的部署。

 

分享到:
评论

相关推荐

    传智播客 赵强 Oracle课件

    赵强老师在传智播客的Oracle课程是专为IT专业人士和对数据库技术感兴趣的学员设计的一系列教学资料,旨在深入浅出地讲解Oracle的核心概念、功能以及实际操作技巧。 在赵强老师的课程中,你可以学到以下几个重要的...

    赵强老师的Oracle课件

    想要好好地学习Oracle数据库的朋友呀,你错过了她就太不值得了。里面有好多的Oracle操作命令可能你都没接触过吧。好了,话不多多说。坚信资料不错!你,值得拥有!OK.还有,之所有要你2分打赏,是我给了你这么好的...

    精通JSP编程 作者赵强

    《精通JSP编程》是赵强先生的一部深入解析JSP技术的专业著作,该书针对JSP编程进行了全面且深入的讲解,旨在帮助读者掌握JSP的核心概念和技术,提升Web应用开发能力。根据提供的文件名列表,我们可以推测书籍的章节...

    精通JSP编程 作者赵强 编

    精通JSP编程 作者赵强 编 12-18节

    Oracle学习笔记(传智播客 赵强)

    1. **使用列名代替通配符(*)**:在编写SQL查询时,避免使用`*`来获取所有列,而应明确指定需要的列名。这样可以减少不必要的数据传输,提高查询速度。 2. **AND和OR操作符的使用策略**:在条件组合中,应将更可能为...

    [1120][赵强精通JSP编程][37M]

    根据提供的文件信息,我们可以推断出这是一份与Java Server Pages (JSP)相关的学习资料介绍,特别是关于赵强编写的《精通JSP编程》这本书的相关信息。下面将基于这个理解来生成相关知识点。 ### 一、JSP基础概念 ...

    day2013-0110-webLogic配置和集群(赵强).zip

    3. 部署应用:使用WebLogic管理控制台或命令行工具`wlst`(WebLogic Scripting Tool)部署Java应用,将WAR、EAR或JAR文件上传到服务器上。 二、WebLogic集群 1. 集群概念:集群是WebLogic的一种高可用性和可扩展性...

    Oracle数据库赵强视频教程【3天】

    教程名称:Oracle 数据库赵强视频教程【3天】教程目录:【】Oracle安装与管理、SQL语句(赵强)【】Orcale存储过程jdbc与Orcale大文本操作等(赵强)【】SQL简单查询触发器视图(赵强)  资源太大,传百度网盘了,链接在...

    LoadRunner性能测试巧匠训练营-完整版(带目录)-赵强邹伟伟

    《LoadRunner性能测试巧匠训练营》是一本深入讲解LoadRunner性能测试的教材,由赵强和邹伟伟两位专家共同编著。该资源提供的是完整版,且无需密码即可解压阅读,对于想要学习和提升LoadRunner性能测试技能的人来说,...

    10天掌握MongoDB

    在MongoDB的使用中,我们可以使用命令行工具进行数据操作,包括创建、读取、更新和删除(CRUD)操作。MongoDB的shell提供了强大的交互式环境,允许用户运行JavaScript脚本进行数据处理和分析。此外,用户还可以通过...

    信息存储技术的发展赵强.doc

    存储技术的昨天,主要围绕着信息的记录和传播方式进行创新。从早期的物理形态记录,如岩画和书籍,到20世纪初的摄影、录音和电影技术,这些都离不开存储技术的进步。进入数字时代,存储技术进一步发展,包括半导体...

    从零开始oracle

    它包含了来自不同源系统的数据,并且经过清洗和整理,以便于进行决策支持分析。 **数据挖掘**:从大量数据中自动发现有意义的模式和规律的过程。常用的技术包括聚类、分类、关联规则学习等。 **图1.3 数据仓库的...

    二年级数学生活中的大数赵强PPT学习教案.pptx

    这篇PPT学习教案主要针对二年级的学生,旨在教授他们在生活中如何理解和使用大数。课程以实际生活中的例子引入,帮助...在教学过程中,教师可能会引导学生进行估算、比较和排序,培养他们的逻辑思维和问题解决能力。

    IT人必知必会的100个课程-终极大揭秘

    丁明一讲师的权威Docker指南课程、贺永康讲师关于使用Docker部署Nextcloud云盘服务的课程,都展示了Docker在当前IT技术中的重要性。 4. 云计算与虚拟化:陈涛讲师的KVM虚拟化进阶与提高视频课程和王春海讲师的使用...

    java代码-46 赖赵强

    在本项目中,标题"java代码-46 赖赵强"暗示了这是一个与Java编程相关的代码示例,可能是由一个名叫赖赵强的开发者编写的。在Java编程领域,这种命名通常是为了记录个人的学习过程或者项目经历。描述中的内容相同,...

Global site tag (gtag.js) - Google Analytics