1、什么是Docker Compose?
Docker Compose是一个用来定义和运行复杂应用的Docker工具。一个使用Docker容器的应用,一般由多个容器组成。使用Docker Compose再也不须要使用shell脚原本启动容器,而使用服务编排的方式来管理容器。
Docker Compose 经过一个配置文件来管理多个Docker容器,在配置文件中,全部的容器经过services来定义,而后使用docker-compose脚原本启动,中止和重启应用,和应用中的服务以及全部依赖服务的容器,很是适合组合使用多个容器进行开发的场景。python
Docker Compose的核心是经过一个YAML文件来管理多个Docker容器,在配置文件中,全部的容器经过services来定义。git
2、什么是YAML文件?
YAML (YML)的意思实际上是:"Yet Another Markup Language"(还是一种置标语言)的缩写。YAML的语法和其余高阶语言相似,而且能够简单表达清单、散列表,标量等资料形态。它使用空格缩排和大量依赖外观的特点,特别适合用来表达或编辑数据结构、各类设定档、倾印除错内容、文件大纲(例如:许多电子邮件标题格式和YAML很是接近)。能够是用 .yml 或 .yaml 做为文件扩展名。github
3、部署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
4、使用Docker Compose构建Python Web应用
这里,咱们将使用两种不一样的方式:手动部署和利用Docker Compose部署,来讲明使用Docker Compose进行部署所带来的好处。web
- 首先,咱们须要建立咱们的应用程序,实现一个简单的计数器功能。这里咱们须要建立三个文件: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来定义咱们的容器组合关系。目录结构下,包含如下文件:redis
其中,docker-compose.yml文件内容以下:docker
version: '3' services: web: build: . ports: - "5000:5000" redis: image: "redis"
执行docker-compose up来启动应用,访问应用程序:http://192.168.15.133:5000/shell
从这里例子中咱们能够看到,经过Docker Compose的YAML配置文件,咱们把两个相关的Service(web和redis)进行了服务编排,从而简化的应用的部署。flask