如何在 PythonAnywhere 上部署多个 Flask 应用

13次阅读

如何在 PythonAnywhere 上部署多个 Flask 应用

pythonanywhere 不支持在单个 web 应用的 `wsgi.py` 中通过多入口方式托管多个独立 flask 应用;正确做法是升级账户后,在 web 控制台为每个应用单独创建并配置对应的 wsgi 文件。

pythonAnywhere 上,一个 Web 应用(Web app)对应一个独立的域名/子路径和一个唯一的 wsgi.py 入口文件。你当前尝试在同一个 wsgi.py 中导入两个 Flask 实例(application 和 new_application),但 PythonAnywhere 的 WSGI 服务器仅识别名为 application 的可调用对象作为主入口——其余变量(如 new_application)会被完全忽略,因此访问 app2 时返回 404 是预期行为。

✅ 正确部署两个 Flask 应用的步骤如下:

  1. 升级账户:免费账户仅允许 1 个 Web 应用;需升级至「Always-on」或「Hobby」及以上套餐,才能添加多个 web apps(如 app1.yourusername.pythonanywhere.com 和 app2.yourusername.pythonanywhere.com)。

  2. 分别创建 Web Apps

    立即学习Python免费学习笔记(深入)”;

    • 进入 PythonAnywhere Web 页面
    • 点击 “Add a new web app” → 选择 Python version → 手动配置;
    • 为 app1 设置源码路径 /home/yourusername/Projects/One/,WSGI 配置指向 /home/yourusername/Projects/One/wsgi.py;
    • 再次点击 “Add a new web app”,为 app2 设置 /home/yourusername/Projects/Two/ 及其专属 wsgi.py。
  3. 为每个项目维护独立的 wsgi.py(示例):

# /home/yourusername/Projects/One/wsgi.py import sys import os  # 添加项目路径(推荐使用绝对路径) path = '/home/yourusername/Projects/One' if path not in sys.path:     sys.path.insert(0, path)  # 激活虚拟环境(如有) activate_this = '/home/yourusername/.virtualenvs/one/bin/activate_this.py' if os.path.exists(activate_this):     exec(open(activate_this).read(), {'__file__': activate_this})  from one import app1 as application  # ✅ 必须命名为 'application'
# /home/yourusername/Projects/Two/wsgi.py import sys import os  path = '/home/yourusername/Projects/Two' if path not in sys.path:     sys.path.insert(0, path)  activate_this = '/home/yourusername/.virtualenvs/two/bin/activate_this.py' if os.path.exists(activate_this):     exec(open(activate_this).read(), {'__file__': activate_this})  from two import app2 as application  # ✅ 同样必须命名为 'application'

⚠️ 注意事项:

  • 不要尝试用 nginx 重写或 Flask 蓝图“合并”两个应用——PythonAnywhere 的 Web App 架构不支持路径级多应用路由(如 /app1/ 和 /app2/ 共存于同一域名);
  • 每个 wsgi.py 必须导出名为 application 的 WSGI 可调用对象;
  • 确保各项目依赖已安装到对应虚拟环境中(可通过 bash console 运行 pip install -r requirements.txt);
  • 修改 wsgi.py 后,务必在 Web 页面点击 “Reload” 按钮生效。

总结:PythonAnywhere 的多应用支持是基于账户层级的 Web App 实例化,而非代码层面的多实例注册。放弃“单文件双应用”的思路,转而采用“一应用一配置、一域名一入口”的标准部署模式,才是稳定、可维护的解决方案。

text=ZqhQzanResources