Ubuntu 14.04 配置 Nginx + uWSGI 托管 virtualenv 下 Flask 应用的一点注意事项

标题很长,本文内容却很简单。在现在的 Python 开发中,虚拟环境是必不可少的,但是有时候,虚拟环境又会给我们带来一些不必要的麻烦或者说坑,比如今天要谈到的 Flask 应用托管的问题。

Nginx + uWSGI 可以说是 Python Web 项目托管的不二之选,当然,如果只是自己开发测试,或者应用在访问量很小的应用上,Gunicorn 甚至 Web 框架自带的 web server 也许就够了,但是我们逃不开会碰到这对王者组合的情况,今天我就遇到了这样的坑。按照官方文档分别配置 Nginx 和 uWSGI 后,使用 uwsgi 的命令语句启动,没有任何问题,但是尝试使用 ini 配置启动 uWSGI 后,则会遇到一直报 502 bad gateway 的错误。

一番排查后——排查过程不表——发现问题所在,我的 uWSGI 安装在了项目的 virtualenv 目录中,然而 ini 配置文件却没有配置虚拟环境目录,而网上现有的博客教程里的 ini 配置都是没有提到这个问题的,所以,我们加上虚拟环境的配置,并且注意,最好加上 plugin = python 这一条配置,当然了,这个需要提前安装,具体如何安装,不是本文重点,暂不赘述了。

所以,我最终的 ini 配置文件内容如下:

[uwsgi]
plugins = python

vhost = true
chdir = /home/k/Documents/demo
venv = /home/k/Documents/demo/venv

#python module to import
app = main
module = %(app)

#socket file's location
socket = /home/k/Documents/demo/%n.sock

#permissions for the socket file
chmod-socket    = 666

#the variable that holds a flask application inside the module imported at line #6
callable = app

#location of log files
logto = /home/k/Documents/demo/%n.log

processes = 4
threads = 2

而我的项目目录结构则是:

demo/
|____venv/
|____main.py # 这个是应用的启动文件(对应 ini 配置中的 app)
|____uwsgi.ini
|____uwsgi.sock
|____uwsgi.log
|____access.log # 这个是 Nginx 中的 access 日志配置
|____error.log # 这个是 Nginx 中的 error 日志配置

你可能感兴趣的:(Python)