docker-compose

docker-compose
用于多镜像部署,有固定的格式

为什么使用Dockerfile?
Dockerfile是一个按一定规则编写的包含多行命令的文件,使用Dockerfile可以快速的构建一个定制的镜像。
传统的方式构建一个工作镜像,我们可能需要使用一个基准镜像、在镜像内安装包、在镜像内编写配置文件、在镜像内编写代码等操作。使用这种方式构建镜像没什么问题,可是试想一下,当你下次需要构建一个相似的镜像,是不是还得重复之前的步骤,当你想分享镜像的时候也需要整个的发送。
但如果使用Dockerfile,它能将每一步改变内容的命令都做commit操作,生成的镜像便于查看history层;使用Dockerfile更加透明,知道具体做了哪些操作;更改更加容器,只需在Dockerfile中更改就可以重新生成镜像,不需要重头来一次;分享更加方便,可以只分享Dockerfile文件,服务器便可以生成一模一样的镜像。
这就是为什么我们通常使用Dockerfile来定制镜像。

创建Dockerfile文件构建镜像示例
在宿主机创建项目目录文件:mkdir flask-project/flask-web-code -p
进入flask-web-code目录中添加主代码文件:vi app.py,编写如下:
from flask import Flask
from redis import Redis

app = Flask(name)
redis = Redis(host="redis",port=6379)

@app.route("/")
def hello():
count = redis.incr('hits')
return 'hello world! {}\n'.format(count)

if name == "main":
app.run(host="0.0.0.0",debug=True,port=9999)
在flask-web-code目录中添加requirements.txt,添加需要pip安装的包,如下:
flask
redis
在flask-project目录中创建并编辑Dockerfile文件:vi Dockerfile,编写如下:

第一步:获取镜像:python3.6

FROM python:alpine3.6

第二步:使用COPY或者ADD拷贝项目代码到镜像中(非比要)

COPY ./flask-web-code /code

切换工作目录

WORKDIR /code

第三步:升级pip,避免后续pip安装失败

RUN pip install --upgrade pip

第三步:使用requirements.txt安装第三方模块

RUN pip install -r requirements.txt

第四步:配置项目的启动 CMD参数 python app.py

CMD ["python","app.py"]
这时候就已经可以使用Dockerfile自动创建flask-app的镜像了,命令:docker build -t flask-app:v1.0 .。
但要想自动完后该项目部署还需要使用到redis镜像。当然这里可以手动启动两个镜像,使用run命令创建容器指定端口映射或数据卷操作来完成项目的部署,但是为了更便捷简单的部署,我们会使用Docker Compose File完成自动部署。详情见下部分内容。

为什么使用Docker Compose File?
按照docker官方的建议,每一个容器只启动一个进程,这样便于管理和解耦。而在生产部署的时候,我们的一个应用不太可能只有一个进程,除了代码应用的主进程外,你可能还需要开启reids、mysql、nginx等。也就是说不会只靠一个镜像便能部署完成,所以我们每次部署应用需要同时用多个镜像启动多个容器,操作端口映射、数据卷,完成容器间的通信。如果涉及到分布式和多台服务器,那岂不是每个服务器都得这样操作一次?因此,docker提供了Docker Compose File,可以使用docker-compose.yaml文件,按照特定的语法语句编写指令,管理多个镜像的部署和端口等操作,实现真证的快速部署。在不同服务器上部署时,只需要一个docker-compose.yaml文件,便能完成应用的部署操作。

制作docker-compose.yaml文件
在flask-project目录内创建并编辑docker-compose.yaml文件:vi docker-compose.yaml,编辑内容如下:
version: "3.6"
services:
flask-web:
build: .
ports:
- "5000:9999"
container_name: flask-web
redis:
image: redis
container_name: redis
version:版本注释,不可缺少的字段。
services:该层级下指明使用镜像开启容器的具体配置,是最主要的配置项。
flask-web、redis:自定义的该service名字。
build:Dockerfile的路径,使用它来创建一个定制的镜像,或者可使用image指定已有镜像。
image:指定使用已有镜像。
ports:开启容器后暴露的端口映射。
container_name:指定开启容器后的容器名。

注意:docker-compose.yaml必须按格式规范来写,最好使用两个空格来表示层级关系。每个参数前面都有一个空格。编写完后使用docker-compose config检查是否有语法错误。

最终的目录层级如下:
└── flask-project
├── docker-compose.yaml
├── Dockerfile
└── flask-web-code
├── app.py
└── requirements.txt

最终部署使用
使用docker-compose config检查语法是否错误
使用docker-compose up -d后台启动服务,过程中会自动根据Dockerfile创建镜像,并且按要求启动服务
使用docker-compose logs检查运行状态
检查项目是否正常运行:curl 127.0.0.1:5000,每次访问能收到变化的数据证明项目部署已经成功完成。
这篇文章并未深入讲各个指令及参数,只为帮助理解我们为什么使用Dockerfile和Docker Compose File。你可以跟着上面的步骤和目录层级做一个实际的操作部署,相信一定能增加你对Dockerfile和Docker Compose File的理解。

链接:https://www.jianshu.com/p/a73ca4bb7dd9

你可能感兴趣的:(docker-compose)