真正需解决的是三类高频部署问题:一是gunicorn因运行用户环境不一致导致ModuleNotFoundError,应使用virtualenv并显式指定解释器路径;二是nginx 502因uWSGI socket通信失败,需检查socket路径、权限及uwsgi_read_timeout配置;三是celery任务丢失,因broker未持久化或启动参数缺失,须配置delivery_mode=2及--pidfile/--logfile。这个标题本身不具备实操价值,不是问题、不是错误、也不是具体技术点。真正需要的不是“第511讲”这种编号式包装,而是你此刻卡在哪个环节:是
pip install 后模块找不到?gunicorn 启动报 Address already in use?还是 Flask 本地能跑,部署到 nginx + uWSGI 就 502?
下面直奔三类高频真实场景:
import numpy 在 shell 里成功,但用 gunicorn 启动就报 ModuleNotFoundError
根本原因:运行用户环境不一致。你用 pip install numpy 是在当前用户(比如 ubuntu)的 Python 环境装的,而 gunicorn 可能以 www-data 用户启动,它压根没这个包。
gunicorn 实际用的 Python 路径:gunicorn --pyth中的onpath /home/ubuntu/myapp --bind 0.0.0.0:8000 myapp:app
--pythonpath 必须指向含依赖的目录virtualenv 创建独立环境,并在启动命令中显式指定解释器:/opt/myapp/venv/bin/gunicorn --bind 0.0.0.0:8000 myapp:app
www-data(或你指定的运行用户)对 venv 目录有读+执行权限,chmod -R 755 /opt/myapp/venv
nginx 返回 502 Bad Gateway,但 uWSGI 日志里没报错这通常不是代码问题,而是通信链路断了——nginx 找不到 uWSGI 进程,或者 socket 权限不对。
uWSGI 是用 socket 模式启动的(不是 --http),且 socket 文件路径与 nginx 配置中 uwsgi_pass 一致,例如:uwsgi --socket /tmp/myapp.sock --chmod-socket=664 --chown-socket=www-data:www-data ...
nginx 配置里必须加这一行:uwsgi_read_timeout 300;否则大响应或慢查询会直接触发 502
ls -l /tmp/myapp.sock,必须是 www-data:www-data 或至少 www-data 有读写权supervisor 管理 celery worker,重启后任务全丢celery 本身不持久化任务状态,supervisor 只管进程生死。任务丢失,是因为 broker(比如 RabbitMQ 或 Redis)没配置消息持久化,或 celery 启动时没加关键参数。
--pidfile 和 --logfile,否则 supervisor 无法准确追踪进程:celery -A myapp.celery worker --loglevel=info --pidfile=/var/run/celery.pid --logfile=/var/log/celery.log
Redis 当 broker,确保 CELERY_BROKER_URL 包含 socket_keepalive=True 参数,避免连接空闲断开delivery_mode=2(持久化):my_task.apply_async(args=[x], delivery_mode=2)