docs(platform): Add database documentation system and restructure deployment docs
Completed: - Add 6 core database documents (docs/01-平台基础层/07-数据库/) Architecture overview, migration history, environment comparison, tech debt tracking, seed data management, PostgreSQL extensions - Restructure deployment docs: archive 20 legacy files to _archive-2025/ - Create unified daily operations manual (01-日常更新操作手册.md) - Add pending deployment change tracker (03-待部署变更清单.md) - Update database development standard to v3.0 (three iron rules) - Fix Prisma schema type drift: align @db.* annotations with actual DB IIT: UUID/Timestamptz(6), SSA: Timestamp(6)/VarChar(20/50/100) - Add migration: 20260227_align_schema_with_db_types (idempotent ALTER) - Add Cursor Rule for auto-reminding deployment change documentation - Update system status guide v6.4 with deployment and DB doc references - Add architecture consultation docs (Prisma guide, SAE deployment guide) Technical details: - Manual migration due to shadow DB limitation (TD-001 in tech debt) - Deployment docs reduced from 20+ scattered files to 3 core documents - Cursor Rule triggers on schema.prisma, package.json, Dockerfile changes Made-with: Cursor
This commit is contained in:
366
docs/05-部署文档/_archive-2025首次部署/15-Node.js后端-部署成功总结.md
Normal file
366
docs/05-部署文档/_archive-2025首次部署/15-Node.js后端-部署成功总结.md
Normal file
@@ -0,0 +1,366 @@
|
||||
# 🎉 Node.js 后端 - 部署成功总结
|
||||
|
||||
> **部署完成时间**:2025-12-24
|
||||
> **最终版本**:v1.3
|
||||
> **内网地址**:`http://172.17.173.71:3001`
|
||||
> **部署状态**:✅ 运行中
|
||||
> **健康检查**:✅ 通过(HTTP 200,响应时间4-15ms)
|
||||
|
||||
---
|
||||
|
||||
## 📊 部署历程概览
|
||||
|
||||
### 版本迭代记录
|
||||
|
||||
| 版本 | 修复问题 | 构建时间 | 状态 | 备注 |
|
||||
|------|---------|---------|------|------|
|
||||
| v1.0 | 初始版本 | ~5分钟 | ❌ 启动失败 | 缺少config目录 |
|
||||
| v1.1 | 添加config目录 | ~1分钟 | ❌ 启动失败 | pino-pretty错误 |
|
||||
| v1.2 | 修复pino-pretty | ~8秒 | ⚠️ 部分成功 | 健康检查500错误 |
|
||||
| **v1.3** | **修复require()** | **~5秒** | **✅ 完全成功** | **生产环境运行中** |
|
||||
|
||||
### 部署时间轴
|
||||
|
||||
```
|
||||
2025-12-24 开始部署
|
||||
↓
|
||||
10:00 - 创建SAE应用,配置环境变量
|
||||
↓
|
||||
10:15 - 部署v1.0,发现缺少config目录 ❌
|
||||
↓
|
||||
10:25 - 修复Dockerfile,构建v1.1 ✅
|
||||
↓
|
||||
10:28 - 部署v1.1,发现pino-pretty错误 ❌
|
||||
↓
|
||||
10:35 - 修改logger配置,构建v1.2 ✅
|
||||
↓
|
||||
10:42 - 部署v1.2,发现require()错误 ❌
|
||||
↓
|
||||
10:45 - 修复ES Module问题,构建v1.3 ✅
|
||||
↓
|
||||
10:50 - 部署v1.3,完全成功!🎉
|
||||
```
|
||||
|
||||
**总耗时**:约50分钟(包含3次问题排查和修复)
|
||||
|
||||
---
|
||||
|
||||
## ✅ 最终部署状态
|
||||
|
||||
### 应用信息
|
||||
```yaml
|
||||
应用名称: nodejs-backend-test
|
||||
命名空间: cn-beijing:test-airesearch
|
||||
地域: 华北2(北京)
|
||||
状态: ✅ 运行中
|
||||
实例数: 1个
|
||||
```
|
||||
|
||||
### 资源配置
|
||||
```yaml
|
||||
CPU: 1核
|
||||
内存: 2GB
|
||||
镜像: backend-service:v1.3
|
||||
镜像大小: ~186MB(压缩后)
|
||||
```
|
||||
|
||||
### 网络配置
|
||||
```yaml
|
||||
内网地址: http://172.17.173.71:3001
|
||||
VPC: vpc-2ze055cptkew9c38w4r06
|
||||
安全组: sg-2zedk6fi8sgmmcwdu7tu
|
||||
公网访问: 无(仅内网)
|
||||
```
|
||||
|
||||
### 健康检查
|
||||
```yaml
|
||||
类型: HTTP
|
||||
路径: /health
|
||||
端口: 3001
|
||||
初始延迟: 30秒
|
||||
检查间隔: 10秒
|
||||
状态: ⚠️ 待修复到v1.3后验证
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 🔧 三次关键修复
|
||||
|
||||
### 修复1:添加config目录(v1.0 → v1.1)
|
||||
|
||||
**问题**:
|
||||
```
|
||||
Error: ENOENT: no such file or directory, open '/app/config/agents.yaml'
|
||||
```
|
||||
|
||||
**解决**:
|
||||
```dockerfile
|
||||
# Dockerfile 添加:
|
||||
COPY config ./config
|
||||
```
|
||||
|
||||
**文档**:[13-Node.js后端-镜像修复记录.md](./13-Node.js后端-镜像修复记录.md)
|
||||
|
||||
---
|
||||
|
||||
### 修复2:条件化pino-pretty(v1.1 → v1.2)
|
||||
|
||||
**问题**:
|
||||
```
|
||||
Error: unable to determine transport target for "pino-pretty"
|
||||
```
|
||||
|
||||
**解决**:
|
||||
```typescript
|
||||
// index.ts 修改:
|
||||
const fastify = Fastify({
|
||||
logger: config.nodeEnv === 'production'
|
||||
? { level: 'info' } // 生产:JSON日志
|
||||
: { level: 'info', transport: {...} } // 开发:pretty格式
|
||||
});
|
||||
```
|
||||
|
||||
**文档**:[14-Node.js后端-pino-pretty问题修复.md](./14-Node.js后端-pino-pretty问题修复.md)
|
||||
|
||||
---
|
||||
|
||||
### 修复3:ES Module适配(v1.2 → v1.3)
|
||||
|
||||
**问题**:
|
||||
```
|
||||
ReferenceError: require is not defined
|
||||
at healthCheck.js:161:43
|
||||
```
|
||||
|
||||
**根源**:
|
||||
```typescript
|
||||
// ❌ ES Module中不能用require
|
||||
loadAverage: require('os').loadavg()
|
||||
```
|
||||
|
||||
**解决**:
|
||||
```typescript
|
||||
// ✅ 使用import
|
||||
import os from 'os'
|
||||
loadAverage: os.loadavg()
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 🎯 部署验证
|
||||
|
||||
### 1. 服务启动验证 ✅
|
||||
|
||||
**日志关键信息**:
|
||||
```
|
||||
✅ Loaded 12 agent configurations
|
||||
[PgBossQueue] Initialized with schema: platform_schema
|
||||
[PostgresCacheAdapter] Cleanup task started
|
||||
✅ 数据库连接成功!
|
||||
📊 数据库版本: PostgreSQL 15.14
|
||||
🚀 Postgres-Only 架构已启动
|
||||
✅ DC模块初始化成功
|
||||
🚀 AI临床研究平台 - 后端服务器启动成功!
|
||||
📍 服务地址: http://localhost:3001
|
||||
Server listening at http://172.17.173.71:3001
|
||||
```
|
||||
|
||||
**验证结果**:✅ 服务完全启动
|
||||
|
||||
---
|
||||
|
||||
### 2. 模块初始化验证 ✅
|
||||
|
||||
| 模块 | 状态 | 验证信息 |
|
||||
|------|------|---------|
|
||||
| **Platform层** | ✅ 成功 | pg-boss队列启动,PostgreSQL缓存启动 |
|
||||
| **AIA模块** | ✅ 成功 | 12个Agent配置加载完成 |
|
||||
| **PKB模块** | ✅ 成功 | RAG引擎初始化 |
|
||||
| **ASL模块** | ✅ 成功 | 路由注册,Workers注册 |
|
||||
| **DC模块** | ✅ 成功 | 6个表存在,7555条数据 |
|
||||
|
||||
---
|
||||
|
||||
### 3. 数据库连接验证 ✅
|
||||
|
||||
```
|
||||
✅ 数据库连接成功!
|
||||
📊 数据库版本: PostgreSQL 15.14
|
||||
📊 当前数据库连接数: 3
|
||||
```
|
||||
|
||||
**验证结果**:✅ RDS PostgreSQL连接正常
|
||||
|
||||
---
|
||||
|
||||
### 4. Workers注册验证 ✅
|
||||
|
||||
```yaml
|
||||
注册的Workers (3个):
|
||||
- asl_screening_batch ✅ # 文献筛选批次处理
|
||||
- dc_extraction_batch ✅ # 数据提取批次处理
|
||||
- dc_toolc_parse_excel ✅ # Tool C Excel解析
|
||||
```
|
||||
|
||||
**验证结果**:✅ 所有异步Workers注册成功
|
||||
|
||||
---
|
||||
|
||||
### 5. 健康检查验证 ⚠️
|
||||
|
||||
**当前状态(v1.2)**:
|
||||
```json
|
||||
{
|
||||
"level":50,
|
||||
"err":{"type":"ReferenceError","message":"require is not defined"}
|
||||
}
|
||||
```
|
||||
|
||||
**需要操作**:更新到v1.3后,健康检查应该返回200
|
||||
|
||||
---
|
||||
|
||||
## 🚀 下一步操作
|
||||
|
||||
### 立即操作:更新到v1.3
|
||||
|
||||
1. **登录SAE控制台**:https://sae.console.aliyun.com/
|
||||
2. **找到应用**:nodejs-backend-test
|
||||
3. **更新镜像版本**:
|
||||
```
|
||||
从:backend-service:v1.2
|
||||
改为:backend-service:v1.3
|
||||
```
|
||||
4. **重新部署**:保存并点击【重新部署】
|
||||
5. **验证健康检查**:
|
||||
```bash
|
||||
curl http://172.17.173.71:3001/health
|
||||
# 应该返回200 OK
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 📊 资源使用情况
|
||||
|
||||
### 成本统计
|
||||
|
||||
| 资源 | 规格 | 月成本 | 状态 |
|
||||
|------|------|-------|------|
|
||||
| RDS PostgreSQL | 2核4GB | ¥260 | ✅ 运行中 |
|
||||
| Python微服务 | 1核2GB | ¥60 | ✅ 运行中 |
|
||||
| **Node.js后端** | **1核2GB** | **¥60** | **✅ 运行中** |
|
||||
| 前端Nginx | 1核2GB | ¥60 | ⏳ 待部署 |
|
||||
| OSS存储 | 10GB | ¥2 | ✅ 运行中 |
|
||||
| NAT网关 | 小型 | ¥60 | ✅ 运行中 |
|
||||
| **当前总计** | - | **¥442/月** | - |
|
||||
|
||||
---
|
||||
|
||||
## 💡 经验教训
|
||||
|
||||
### 1. Docker镜像完整性检查
|
||||
|
||||
**问题**:忘记复制config目录
|
||||
**教训**:构建前检查清单
|
||||
```bash
|
||||
✅ node_modules
|
||||
✅ dist
|
||||
✅ prisma
|
||||
✅ config ← 容易遗漏!
|
||||
✅ package.json
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### 2. 环境适配
|
||||
|
||||
**问题**:开发工具(pino-pretty)用在生产环境
|
||||
**教训**:根据NODE_ENV条件化配置
|
||||
```typescript
|
||||
config.nodeEnv === 'production' ? A : B
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### 3. ES Module vs CommonJS
|
||||
|
||||
**问题**:混用require()和import
|
||||
**教训**:项目统一使用ES Module,避免require()
|
||||
```typescript
|
||||
// ❌ 不要用
|
||||
const os = require('os')
|
||||
|
||||
// ✅ 使用
|
||||
import os from 'os'
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 📝 技术亮点
|
||||
|
||||
### 1. Postgres-Only架构 🏆
|
||||
|
||||
- ✅ 无需Redis,降低成本约¥700/年
|
||||
- ✅ pg-boss队列:异步任务处理
|
||||
- ✅ PostgreSQL缓存:性能优化
|
||||
- ✅ 3个Workers:ASL、DC批处理
|
||||
|
||||
### 2. 云原生适配 ☁️
|
||||
|
||||
- ✅ 无状态应用
|
||||
- ✅ 容器化部署
|
||||
- ✅ 健康检查配置
|
||||
- ✅ 内网服务发现
|
||||
|
||||
### 3. 生产环境优化 ⚡
|
||||
|
||||
- ✅ JSON日志(性能10倍于pino-pretty)
|
||||
- ✅ 数据库连接池优化
|
||||
- ✅ Alpine镜像(体积小)
|
||||
- ✅ 多阶段构建(安全)
|
||||
|
||||
---
|
||||
|
||||
## 🎉 部署成功!
|
||||
|
||||
### 当前状态
|
||||
|
||||
```
|
||||
✅ 服务运行中
|
||||
✅ 数据库连接正常
|
||||
✅ 所有模块初始化成功
|
||||
✅ Workers注册完成
|
||||
⚠️ 健康检查待v1.3验证
|
||||
```
|
||||
|
||||
### 内网地址(重要!)
|
||||
|
||||
```
|
||||
Node.js后端:http://172.17.173.71:3001
|
||||
Python微服务:http://172.17.173.66:8000
|
||||
```
|
||||
|
||||
**前端Nginx配置时需要用到这个地址!**
|
||||
|
||||
---
|
||||
|
||||
## 📞 后续支持
|
||||
|
||||
### 监控建议
|
||||
|
||||
1. 配置SAE应用监控告警
|
||||
2. 查看实时日志排查问题
|
||||
3. 监控CPU/内存使用率
|
||||
|
||||
### 扩容建议
|
||||
|
||||
如果1核2GB不够:
|
||||
- 推荐:2核4GB(¥120/月)
|
||||
- 配置弹性伸缩(按需扩容)
|
||||
|
||||
---
|
||||
|
||||
**🎉 恭喜!Node.js后端已成功部署到阿里云SAE!**
|
||||
**📝 文档维护:运维团队**
|
||||
**📅 最后更新:2025-12-24**
|
||||
|
||||
Reference in New Issue
Block a user