Doker容器化部署03 -镜像生成(Dockerfile)与启动容器

利用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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值