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

本文分享了一次配置Nginx+uWSGI部署Flask应用的经历,特别是解决了因未正确配置虚拟环境而导致的502 Bad Gateway错误。文中详细介绍了正确的uWSGI ini配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

标题很长,本文内容却很简单。在现在的 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 日志配置
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值