1.8 KiB
1.8 KiB
审计记录:后端依赖补全使 FastAPI 可启动
- 日期:2026-02-15(Asia/Shanghai)
- Prompt:「MCP 服务器调用 http://127.0.0.1:8000/health 时后端没跑……我要让 FastAPI 成功启动,需要怎么操作,你能帮我实现么?」
直接原因
apps/backend/pyproject.toml 的 dependencies 仅声明了 neozqyy-shared,缺少 fastapi、uvicorn、psycopg2-binary、python-dotenv 等实际运行依赖,导致 uv run uvicorn 无法找到这些包,后端无法启动。
修改方案:在 pyproject.toml 中补全四个运行依赖,执行 uv sync --all-packages 安装,使后端可正常启动并响应 /health。
修改文件清单
| 文件 | 变更类型 | 说明 |
|---|---|---|
apps/backend/pyproject.toml |
修改 | 补全 fastapi/uvicorn[standard]/psycopg2-binary/python-dotenv 依赖 |
apps/backend/README.md |
重写 | 修复损坏的 markdown 代码块,更新依赖版本号和启动命令 |
风险点
- 依赖版本范围(>=0.115 等)较宽松,未来 breaking change 可能影响启动;建议后续考虑 pin 上限
uvicorn[standard]引入了 uvloop/httptools/websockets 等额外依赖,Windows 上 uvloop 不可用但 uvicorn 会自动降级- 不涉及业务逻辑、数据库 schema、API 契约变更
回滚要点
# 回滚 pyproject.toml dependencies 为:
dependencies = [
"neozqyy-shared",
]
# 然后执行 uv sync --all-packages
验证步骤
# 1. 确认依赖安装
uv sync --all-packages
# 2. 启动后端
cd apps/backend
uv run uvicorn app.main:app --host 127.0.0.1 --port 8000
# 3. 验证健康检查
curl http://127.0.0.1:8000/health
# 预期返回:{"status":"ok"}
# 4. 验证 OpenAPI 文档可访问
# 浏览器打开 http://127.0.0.1:8000/docs