欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

flask项目部署

程序员文章站 2022-06-11 11:57:05
...

项目开发完成

1.测试排除项目存在的BUG
2.用pip freeze > requirements.txt将当前环境的包导出到requirements.txt文件中,方便在部署的时候安装

服务器上准备

1.安装virtualenv以及virutalenvwrapper。并创建虚拟环境。

pip3 install virtualenv
pip3 install virtualenvwrapper
sudo apt install vim
vim ~/.bashrc 进入文件中,填入以下两行代码:
  export WORKON_HOME=$HOME/.virtualenvs
  source /usr/local/bin/virtualenvwrapper.sh

2.创建虚拟环境

mkvirtualenv --python=/usr/bin/python3 zlbbs-env

3.安装MySQL服务器和客户端:

sudo apt install mysql-server mysql-client
sudo apt-get install libmysqld-dev

4.进入虚拟环境中,然后进入到项目所在目录,执行命令:pip install -r requirements.txt安装好相应的包。

5.在mysql数据库中,创建相应的数据库。

安装uwsgi

1.通过pip install uwsgi 安装 uwsgi (uwsgi必须安装在系统级别的Python环境中,不要安装到虚拟环境中)。
2.使用命令uwsgi --http :8000 --wsgi-file programdir/program_name.py -callable app -H 虚拟环境路径。用uwsgi启动项目,如果能够在浏览器中访问到这个页面,说明uwsgi可以加载项目了。

通过配置文件运行uwsgi

在项目的路径下面,创建一个文件叫做program_name_uwsgi.ini的文件,然后填写以下代码:

//文件名:program_name_uwsgi.ini
[uwsgi]
master = true      
processes = 4     //内核数
#http = 0.0.0.0:8000     //测试uwsgi的时候使用这个注释掉socket
socket  = /home/tmp/programname.sock   //socket 文件,用于和nginx通信,推荐不要放在项目目录下,不然可能会报错,提示找不到该文件
pythonpath = programdir     //程序路径    
module = program_name      //程序名字(和下面python文件名相同,不包含.py)
wsgi-file=program_dir/program_name.py    //python文件名
callable = app                           //注意,python文件内的app需要作为全局变量引出,不然会找不到                                  
chmod-socket    = 666
touch-reload= programdir                         //文件路径
vacuum = true

然后使用命令uwsgi --ini program_name_uwsgi.ini,看下是否还能启动这个项目。(如果选择socket可能会运行失败,提示没有sock文件,这时候可以先进行下一步nginx的部署,nginx会自动生成sock文件)

安装nginx:

nginx是一个web服务器。用来加载静态文件和接收http请求的。通过命令sudo apt install nginx即可安装。
nginx常用命令:

启动nginx:service nginx start
关闭nginx:service nginx stop
重启nginx:service nginx restart
测试nginx:service nginx configtest
差错nginx:nginx -t                  //查错,如有错会在终端报错

编写nginx配置文件:

在/etc/nginx/conf.d目录下,新建一个文件,叫做program_name.conf,然后将以下代码粘贴进去:

upstream program_name{
    server unix:///home/tmp/program_name.sock; #该sock文件与上面uwsgi配置文件内的sock文件应当为同一个文件,最好不要放在项目目录下,不然可能出显示找不到该文件。
}
# 配置服务器
server {
    # 监听的端口号
    listen      80;    # 这个是nginx输出的端口,也就是说后面你访问你的网站实例需要登录这个端口,添加端口映射时需要注意
    # 域名
    server_name  192.168.1.1; #此处填写域名或者ip,多个的情况下空格隔开
    charset     utf-8;

    # 最大的文件上传尺寸
    client_max_body_size 75M;

    # 静态文件访问的url
    location /static {
        # 静态文件地址
        alias  programdir/static;           #此处填写static文件路径
    }

    # 最后,发送所有非静态文件请求到django服务器
    location / {
        uwsgi_pass  oderaway;
        # uwsgi_params文件地址
        include     /etc/nginx/uwsgi_params;
    }
}

写完配置文件后,为了测试配置文件是否设置成功,运行命令:service nginx configtest,如果不报错,说明成功,如果失败了,可以执行nginx -t,该指令会打印出来出错的地方。
每次修改完了配置文件,都要记得运行service nginx restart

使用supervisor配置:

让supervisor管理uwsgi,可以在uwsgi发生意外的情况下,会自动的重启。
1.supervisor的安装:
在系统级别的python环境下pip install supervisor。(这里如果你用的是python3写的项目,也可以直接用pip安装启动supervisor,也就是python2,supervisor安装在3或者2,对你的项目没有任何影响)
2.在项目的根目录下创建一个文件叫做program_name_supervisor.conf。内容如下:

# supervisor的程序名字
    [program:program_name]     #program_name 该名称可以随意设置
    # supervisor执行的命令
    command=uwsgi --ini program_name_uwsgi.ini
    # 项目的目录
    directory = programdir
    # 开始的时候等待多少秒
    startsecs=0
    # 停止的时候等待多少秒
    stopwaitsecs=0  
    # 自动开始
    autostart=true
    # 程序挂了后自动重启
    autorestart=true
    # 输出的log文件
    stdout_logfile=programdir/log/supervisord.log          #这里你可能需要先创建log路径
    # 输出的错误文件
    stderr_logfile=programdir/log/supervisord.err            #同上

    [supervisord]
    # log的级别
    loglevel=info

    # 使用supervisorctl的配置
    [supervisorctl]
    # 使用supervisorctl登录的地址和端口号
    serverurl = http://127.0.0.1:9001

    # 登录supervisorctl的用户名和密码
    username = 自定义
    password = 自定义

    [inet_http_server]
    # supervisor的服务器
    port = :9001
    # 用户名和密码
    username = 自定义
    password = 自定义

    [rpcinterface:supervisor]
    supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

然后使用命令supervisord -c program_name_supervisor.conf运行就可以了。
以后如果想要启动uwsgi,就可以通过命令supervisorctl -c program_name_supervisor.conf进入到管理控制台,然后可以执行相关的命令进行管理:
指令如下:

status # 查看状态
start program_name #启动程序
restart program_name #重新启动程序
stop program_name # 关闭程序
reload # 重新加载配置文件
quit # 退出控制台