在准备环境前提交次全部更改。

This commit is contained in:
Neo
2026-02-19 08:35:13 +08:00
parent ded6dfb9d8
commit 4eac07da47
1387 changed files with 6107191 additions and 33002 deletions

View File

@@ -0,0 +1,51 @@
# 审计记录:后端依赖补全使 FastAPI 可启动
- 日期2026-02-15Asia/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 契约变更
## 回滚要点
```toml
# 回滚 pyproject.toml dependencies 为:
dependencies = [
"neozqyy-shared",
]
# 然后执行 uv sync --all-packages
```
## 验证步骤
```bash
# 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
```