<center>nginx+uWSGI+supervisor+flask项目部署</center>
nginx+uWSGI+Flask+Supervisor部署项目
OS version: Ubuntu 16.04.2
nginx version: nginx/1.10.3 (Ubuntu)
uWSGI version: uWSGI (2.0.15)
Flask version: Flask (0.12.2)
Supervisor version: Supervisor(3.2.0)
nginx 配置 新建文件 /etc/nginx/conf.d/xxx.conf xxx.conf 中xxx你来定
删除/etc/nginx/sites-enabled/ 以及 /etc/nginx/sites-available/ 下所有文件
你可以这么玩,sudo rm -f /etc/nginx/sites-enabled/default
为什么这么做呢?
先看nginx.conf里面有:
include /etc/nginx/conf.d/.conf;
include /etc/nginx/sites-enabled/;
而sites-enabled里面也有default这种文件,我这么做的原因是删了看着干净。以后做扩展找起来也好找,都在conf.d目录下。
极简配置
客户端访问80端口,有Nginx接受到请求,并下发到服务器6001端口进行处理,6001端口会部署一个uWSGIweb服务器.
server {
listen 80;
server_name www.smallstrong.site; #公网地址
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:6001;
}
}
Nginx常用的几个命令:
sudo service nginx start
sudo service nginx stop
sudo service nginx restart
pip全局安装virtualenv在自己项目根目录新建一个独立的Python环境
- pip install virtualenv
- cd 到你项目根目录
- virtualenv api_env
- source api_env/bin/activate (deactivate 可退出)
- 接下来pip来安装自己需要的Python库,Flask,uWSGI等(依赖问题自行解决)
接下来写一个最简单的Flask应用
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask import Flask
app = Flask(__name__)
whale_apis = {
'test'
}
@app.route('/api/<func>', methods=['GET', 'POST'])
def go(func):
exec 'import fe.' + func
data = eval('fe.' + func + '.go()')
return data
if __name__ == '__main__':
app.run(debug=True)
上面的代码是我的flask网络框架的主入口,路由是/api/方法名称,默认接受GET 和 POST请求,动态导入工程目录下fe目录下的同方法名文件,执行go方法并返还数据。fe目录是所有网络请求目录,后续在剖析Flask应用会详细介绍。
写好Flask入口之后,写一个uWSGI服务器的配置文件
[uwsgi]
# uwsgi 启动时所使用的地址与端口
socket = 127.0.0.1:6001
module = manage:app
# 处理器数
processes = 4
# 线程数
threads = 2
req-logger = file:/home/small/logs/req.log
logger = file:/home/small/logs/err.log
放在项目根目录下,取名叫uwsgi.ini
这时候 命令行输入 uwsgi uwsgi.ini 即开启了uWSGI服务器。
Supervisor安装管理uwsgi进程
[program:whale_api]
command=/home/small/whale/whale_api/api_env/bin/uwsgi /home/small/whale/whale_api/uwsgi.ini
directory=/home/small/whale/whale_api
user=root
autostart=true
autorestart=true
startretries=3
stdout_logfile=/home/small/logs/supervisor_out.log
stderr_logfile=/home/small/logs/supervisor_err.log
默认生成的配置文件里面会有一部分要修改,包括日志输出位置。
serverurl=unix:///var/run/supervisor.sock找不到原因是你杀死supervisord进程重新开或是权限不足,反正这块坑还是比较多的
启动supervisor
sudo supervisord -c supervisord.conf
管理常用指令:
sudo supervisorctl shutdown //会关闭supervisor进程和其管理的子进程
sudo supervisorctl status //查看现在运行的supervisor进程的状态
sudo supervisorctl start
sudo supervisorctl stop
sudo supervisorctl restart
昨晚的结果就是:
这只是万里长征第一步。写下这些命令也只是方便日后出问题了来查阅,不至于很闷逼。相信还有很多未知的问题在等待这我,等我踩完会继续在文章中填上。下班回家!