4.3 KiB
4.3 KiB
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 中两处调用仍使用无参构造函数:
# 错误代码
return AIHandler()
# 正确代码
return AIHandler(ai_service=AIService())
三、修复内容
3.1 数据库修复(已完成)
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 本地打包
cd D:\资料\03-项目开发\wecom_it_smart_desk\deploy-server
.\打包部署.bat
生成文件:
it-smart-desk-server-deploy.zip— 前端+nginx+docker-composedeploy-backend.tar— 后端 Docker 镜像(含修复)
4.2 上传服务器
通过堡垒机将文件上传到服务器 /tmp/:
it-smart-desk-server-deploy.zipdeploy-backend.tar
4.3 服务器部署
# 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 后端健康检查
curl https://itsupport.servyou.com.cn/health
# 预期返回:{"status":"ok"}
5.2 H5 消息发送测试
- H5 Mock 登录:
POST /api/h5/mock-login - 发送消息:
POST /api/h5/conversations/current/messages - 预期:返回 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 | 初始记录,数据库修复 + 代码修复 + 打包脚本 |