Dockerfile与docker-compose.yml文件的作用及自动部署的实现

为什么使用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

最终部署使用

  1. 使用docker-compose config检查语法是否错误
  2. 使用docker-compose up -d后台启动服务,过程中会自动根据Dockerfile创建镜像,并且按要求启动服务
  3. 使用docker-compose logs检查运行状态
  4. 检查项目是否正常运行:curl 127.0.0.1:5000,每次访问能收到变化的数据证明项目部署已经成功完成。

这篇文章并未深入讲各个指令及参数,只为帮助理解我们为什么使用Dockerfile和Docker Compose File。你可以跟着上面的步骤和目录层级做一个实际的操作部署,相信一定能增加你对Dockerfile和Docker Compose File的理解。

以上,有错误之处诚请指出。

你可能感兴趣的:(Dockerfile与docker-compose.yml文件的作用及自动部署的实现)