364e688382
主要改动: backend 业务: - feat(error-codes): 统一错误码表 E1011/E1012 拆码 - E1011 AUTH_PASSWORD_WRONG: 本地密码错误 - E1012 AUTH_FIRST_LOGIN_PASSWORD_REQUIRED: 首次登录请先设置密码 - E1015 AUTH_OLD_PASSWORD_REQUIRED: 改密需要旧密码 - E1016 AUTH_OLD_PASSWORD_WRONG: 旧密码错误 - fix(agents): P0 降级放行时,如坐席已注册但未设密码,正确 raise 1012 (修复前会撞 1011 本地密码错误,与场景不符) - feat(approval): 审批模块 (T审批/A审批) - feat(config): approval_template_resource / approval_template_device 配置 - feat(main): /ready, /metrics, /version 端点(K8s 友好) backend 测试: - test(agents): 新增 test_agents.py — 3 个 Fix-4 降级登录测试 - 错误密码拒绝 - 缺密码拒绝 - 正确密码通过 pytest tests/test_agents.py → 3/3 通过 - test(conftest): 模块级 mock + slowapi 限流重置 + UTF-8 patch 解决 Windows pytest GBK 读 .env 失败 + 降级路径无法测试 仓库治理: - chore(gitignore): 排除 .workbuddy/memory/(workbuddy 本地记忆) - chore(docs): 重命名两份 IT 文档(前缀加智能区分版本) 部署与文档: - docs: RELEASE_NOTES_v0.5.0-beta.md / dashboard.html / 需求-发版预览页面 - docs: 部署、架构、PRD、安全、评审报告等同步 v0.5.0-beta - deploy-server: 打包脚本、nginx、docker-compose 版本号 bump 前端 (frontend-h5 / frontend-agent / frontend-admin / frontend-portal): - index.html / package.json 版本号与构建号 bump 自动验收(RELEASE_NOTES L100-104): - [x] pytest tests/test_agents.py -v → 3 passed - [x] grep Bs7ucT backend frontend-h5 frontend-agent → 无输出 - [x] grep AppException(101[123]) backend → 仅 1 处(登录场景 1012) - [ ] npm run build (frontend-h5 / frontend-agent) → 合并后跑 后续: 合并 feature/t-1-t4-merge → main,tag v0.5.0-beta
185 lines
4.3 KiB
Markdown
185 lines
4.3 KiB
Markdown
# 智能IT支持服务台 - 部署修复记录
|
||
|
||
**日期**:2026-06-13
|
||
**负责人**:宋献
|
||
**状态**:待部署验证
|
||
|
||
---
|
||
|
||
## 一、问题概述
|
||
|
||
### 1.1 部署后 H5 用户端报错
|
||
|
||
```
|
||
POST /api/h5/conversations/current/messages 返回 500 错误:
|
||
- 错误1:column conversations.impact_scope does not exist
|
||
- 错误2:AIHandler.__init__() missing 1 required positional argument: 'ai_service'
|
||
```
|
||
|
||
### 1.2 影响范围
|
||
|
||
| 系统 | 影响 | 说明 |
|
||
|------|------|------|
|
||
| H5 用户端 | 阻塞 | 无法发送消息触发 AI 回复 |
|
||
| Dify AI | 无法测试 | 依赖 H5 消息发送 |
|
||
| 管理后台 | 已修复 | admin001 已设为管理员 |
|
||
|
||
---
|
||
|
||
## 二、根因分析
|
||
|
||
### 2.1 数据库缺列
|
||
|
||
服务器上数据库 `conversations` 表缺少4个新增列:
|
||
- `impact_scope` — 影响范围
|
||
- `is_blocking` — 是否阻塞
|
||
- `emotion_state` — 情绪状态
|
||
- `dify_conversation_id` — Dify 会话ID
|
||
|
||
### 2.2 AIHandler 初始化错误
|
||
|
||
代码重构后 `AIHandler.__init__` 需要传入 `AIService` 实例,但 `dependencies.py` 中两处调用仍使用无参构造函数:
|
||
|
||
```python
|
||
# 错误代码
|
||
return AIHandler()
|
||
|
||
# 正确代码
|
||
return AIHandler(ai_service=AIService())
|
||
```
|
||
|
||
---
|
||
|
||
## 三、修复内容
|
||
|
||
### 3.1 数据库修复(已完成)
|
||
|
||
```sql
|
||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS impact_scope VARCHAR(50);
|
||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS is_blocking BOOLEAN DEFAULT false;
|
||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS emotion_state VARCHAR(50);
|
||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS dify_conversation_id VARCHAR(255);
|
||
```
|
||
|
||
### 3.2 代码修复
|
||
|
||
**文件**:`backend/app/dependencies.py`
|
||
|
||
**修复内容**:2处 AIHandler 调用补上 ai_service 参数
|
||
|
||
| 位置 | 修复前 | 修复后 |
|
||
|------|--------|--------|
|
||
| get_shared_ai_handler() | `return AIHandler()` | `return AIHandler(ai_service=AIService())` |
|
||
| dep_ai_handler() | `return AIHandler()` | `return AIHandler(ai_service=AIService())` |
|
||
|
||
---
|
||
|
||
## 四、部署步骤
|
||
|
||
### 4.1 本地打包
|
||
|
||
```powershell
|
||
cd D:\资料\03-项目开发\wecom_it_smart_desk\deploy-server
|
||
.\打包部署.bat
|
||
```
|
||
|
||
生成文件:
|
||
- `it-smart-desk-server-deploy.zip` — 前端+nginx+docker-compose
|
||
- `deploy-backend.tar` — 后端 Docker 镜像(含修复)
|
||
|
||
### 4.2 上传服务器
|
||
|
||
通过堡垒机将文件上传到服务器 `/tmp/`:
|
||
- `it-smart-desk-server-deploy.zip`
|
||
- `deploy-backend.tar`
|
||
|
||
### 4.3 服务器部署
|
||
|
||
```bash
|
||
# 1. 加载后端镜像
|
||
docker load -i /tmp/deploy-backend.tar
|
||
|
||
# 2. 重启后端容器
|
||
docker stop wecom_it_backend && docker rm wecom_it_backend
|
||
docker run -d --name wecom_it_backend ... (原启动命令)
|
||
|
||
# 3. 验证后端健康
|
||
curl https://itsupport.servyou.com.cn/health
|
||
```
|
||
|
||
---
|
||
|
||
## 五、验证检查项
|
||
|
||
### 5.1 后端健康检查
|
||
|
||
```bash
|
||
curl https://itsupport.servyou.com.cn/health
|
||
# 预期返回:{"status":"ok"}
|
||
```
|
||
|
||
### 5.2 H5 消息发送测试
|
||
|
||
1. H5 Mock 登录:`POST /api/h5/mock-login`
|
||
2. 发送消息:`POST /api/h5/conversations/current/messages`
|
||
3. 预期:返回 AI 回复(调用 Dify 成功)
|
||
|
||
### 5.3 Dify AI 集成状态
|
||
|
||
管理后台 → 集成配置 → Dify AI 状态应为 `connected`
|
||
|
||
---
|
||
|
||
## 六、相关配置
|
||
|
||
### 6.1 服务器信息
|
||
|
||
| 项目 | 值 |
|
||
|------|------|
|
||
| 服务器 IP | 10.90.5.110 |
|
||
| 域名 | itsupport.servyou.com.cn |
|
||
| WAF | 115.236.188.3 |
|
||
|
||
### 6.2 企微配置
|
||
|
||
| 项目 | 值 |
|
||
|------|------|
|
||
| CorpID | wwa8c87970b2011f41 |
|
||
| AgentID | 1000133 |
|
||
| Token | wAqMCP |
|
||
| EncodingAESKey | KQY3cEsBc3rdi3xua9rPd5WxH8kYOhyASzWZQf75aJS |
|
||
|
||
### 6.3 Dify 配置
|
||
|
||
| 项目 | 值 |
|
||
|------|------|
|
||
| API URL | http://yw-dify.dc.servyou-it.com/dify2openai/v1/chat/completions |
|
||
| API Key | http://yw-dify.dc.servyou-it.com/v1\|app-UaTWYdBSwN6VktKQlbh5YN5H\|Chat |
|
||
|
||
### 6.4 数据库配置
|
||
|
||
| 项目 | 值 |
|
||
|------|------|
|
||
| 数据库 | PostgreSQL |
|
||
| 库名 | wecom_it_desk |
|
||
| 用户 | wecom |
|
||
| 密码 | wecom_secret_2026 |
|
||
|
||
---
|
||
|
||
## 七、相关文件
|
||
|
||
| 文件路径 | 说明 |
|
||
|---------|------|
|
||
| `backend/app/dependencies.py` | 修复后的代码 |
|
||
| `deploy-server/build-and-deploy.ps1` | 打包部署脚本 |
|
||
| `deploy-server/打包部署.bat` | 一键执行入口 |
|
||
| `docs/IT服务台PRDv1.0.md` | 产品需求文档 |
|
||
|
||
---
|
||
|
||
**更新历史**
|
||
|
||
| 日期 | 更新内容 |
|
||
|------|---------|
|
||
| 2026-06-13 | 初始记录,数据库修复 + 代码修复 + 打包脚本 | |