利用docker对gunicorn应用和nginx进行容器化部署
一.将应用进行镜像生成打包
方法:利用dockerflie,在基础镜像(docker pull可拉取基础centos镜像)配合下,生成新的docker镜像
dockerfile
# 基础镜像
FROM centos_7_base
# 作者
MAINTAINER Jayyywah "xxxx@163.com"
# 后面进行相关命令的执行
# gunicorn应用服务的安装
# 生成文件夹并切换到目录之下
WORKDIR Attendance_sys
# 拷贝系统相关信息
COPY XXX ./XXXX
COPY logs ./logs
COPY boot.sh .
COPY gunicorn_config.py .
COPY ......等等
# 清空已有的日志文件, RUN为执行相关命令
RUN rm -rf ./logs/*.log
RUN rm -rf ./logs/*.pid
# 创建虚拟环境
RUN virtualenv -p /usr/bin/python venv # 保证基础镜像里有virtualenv和python3
RUN venv/bin/pip install -r requirements.txt # 下载相关依赖
# 抛出容器的端口
EXPOSE 6666
# 前面的boot.sh文件是容器启动脚本,所以设置启动容器就运行脚本
RUN chmod a+x boot.sh # 启动权限
# 容器启动应该执行的默认脚本命令
ENTRYPOINT ["./boot.sh"]
解:boot.sh文件主要是激活虚拟环境,并运行gunicorn命令的脚本。
#!/bin/bash
# 激活虚拟环境
source ./venv/bin/activate
# 运行gunicorn应用
exec gunicorn start:app -c gunicorn_config.py # start是启动文件名
上面的Dokcerfile已经编写完成,通过命令进行镜像生成(在有Dokcerfile文件的目录下运行):
docker bulid -t image_name:tag .
镜像完成后,根据镜像进行启动容器(-p是端口映射)
docker run -it --name your_cont_name -p 8000:8000 image_name
启动后可进入容器进行修改
docker exec -it your_cont_name /bin/bash