【赵渝强老师】使用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)进行了服务编排,从而简化的应用的部署。
- JDK8 stream toMap() java.lang.IllegalStateException: Duplicate key异常解决(key重复)
- 如约而至,Java 10 正式发布!
- Intellij IDEA查看所有断点
- Spring Boot国际化支持
- 有记忆会推理的可微分神经计算机,DeepMind现在开源了代码
- Spring Boot整合Thymeleaf模板引擎
- Spring Boot实现热部署
- Java中的宏变量,宏替换详解。
- 类、变量、块、构造器、继承初始化顺序,终极解答。
- Spring Boot Debug调试
- Maven精选系列--classifier元素妙用
- PostgreSQL里面的一些命令小结
- Java中创建String的两道面试题及详解
- PostgreSQL主备环境搭建
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- R练习50题 - 第一期
- [889]python处理HTML转义字符
- python 利用jinja2模板生成html代码实例
- vue项目使用 富文本 封装
- typescript基础篇(5):类
- .Net微服务实战之Kubernetes的搭建与使用
- 使用Prometheus监控Golang服务-基于YoyoGo框架
- 使用jedis面临的非线程安全问题
- 基于UVM的UART验证环境
- 潘石屹用Python解决100个问题 | 打印菱形
- Android:源码解析 Dialog的窗口机制
- Java|获取图片rgb值
- (数据科学学习手札93)利用geopandas与PostGIS进行交互
- 设计模式(三):旅行的角度理解抽象工厂模式
- 机器学习中的优化算法!