
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 个 Web 应用;需升级至「Always-on」或「Hobby」及以上套餐,才能添加多个 Web Apps(如 app1.yourusername.pythonanywhere.com 和 app2.yourusername.pythonanywhere.com)。
-
分别创建 Web Apps:
立即学习“Python免费学习笔记(深入)”;
PHP168 行业B2B下载解决问题如下:只列举最近用户提交问题,其余问题前面几次补丁已经解决,不在复述。1、解决搜索问题。以前搜索一定要确定到省下面的某个市,这个不符合用户体验。 现在改为,省--所有城市(默认为所有城市,也可以自己选择某个市)。2、解决首页推荐产品部显示问题。(以前没有考虑多个其他浏览器)3、解决供应、求购 今日产品显示问题。(理由同上)4、解决收藏商家、供应、求购问题。 (链接错误)5、解决后台分类过
- 进入 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。
为每个项目维护独立的 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 实例化,而非代码层面的多实例注册。放弃“单文件双应用”的思路,转而采用“一应用一配置、一域名一入口”的标准部署模式,才是稳定、可维护的解决方案。









