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
7.1 KiB
7.1 KiB
企微智能IT支持服务台 — 远程服务器部署指南(预生产)
预生产环境:本系统与 IT 数据查询平台部署在不同主机。正式环境将迁移到 K8s。
部署架构
浏览器 ──→ it-dataquery.dc.servyou-it.com:80
│
▼
┌─── nginx (本系统主机) ──────────────────────┐
│ │
│ /itdesk/* → H5 员工端 SPA │
│ /itagent/* → 坐席工作台 SPA │
│ /api/* → backend:8000 (FastAPI) │
│ /ws/* → backend:8000 (WebSocket) │
│ /* → 远程代理到数据平台主机 IP │ ← 跨主机
│ │
└──────────────┬─────────────────────────────┘
│ 本机 Docker 网络
┌─────────────┼─────────────┐
▼ ▼ ▼
┌──────────┐ ┌──────────┐ ┌──────────┐
│ backend │ │ postgres │ │ redis │
│ :8000 │ │ :5432 │ │ :6379 │
└──────────┘ └──────────┘ └──────────┘
网络互联
预生产环境中,数据平台在独立主机,不需要 Docker 网络互联。Nginx 通过远程 IP 直接反代数据平台:
本系统主机 (Docker) 数据平台主机
┌──────────────────┐ ┌─────────────────┐
│ nginx ──────────┼── HTTP 反代 ──→ │ 数据平台 :80 │
│ │ │ 远程 IP │ │
│ ▼ │ └─────────────────┘
│ backend:8000 │
│ postgres:5432 │
│ redis:6379 │
└──────────────────┘
前置条件
- 服务器已安装 Docker + Docker Compose
- IT 数据查询平台已部署运行
- 有 SSH 登录权限
部署步骤
1. 配置数据平台反代地址
预生产环境中,数据平台在独立主机。部署前,必须将 nginx 配置中的数据平台上游地址改为实际 IP。
编辑 nginx/nginx.conf:
# 将 DATAQUERY_HOST 替换为数据平台主机的实际 IP:端口
upstream dataquery {
server 10.80.0.86:80; # ← 改为数据平台实际 IP
}
不再需要创建
it-platform-net—— Docker 网络无法跨主机互联。nginx 通过 HTTP 直接反代到远程 IP。
3. 上传部署包
在本地(Windows)执行:
# 方式 A:使用 deploy.sh 打包
bash scripts/deploy.sh --pack
scp it-smart-desk-*.tar.gz user@server:/opt/
# 方式 B:手动打包
tar czf deploy.tar.gz \
backend/ frontend-h5/dist/ frontend-agent/dist/ \
nginx/ docker-compose.yml .env.production scripts/
scp deploy.tar.gz user@server:/opt/it-smart-desk/
4. 服务器上解压和配置
ssh user@server
cd /opt/it-smart-desk
tar xzf it-smart-desk-*.tar.gz
# 创建环境配置(填入真实企微凭证)
cp .env.production .env
vim .env
.env 必填项:
| 配置项 | 说明 | 获取位置 |
|---|---|---|
WECOM_CORP_ID |
企业ID | 企微管理后台 > 我的企业 |
WECOM_AGENT_ID |
应用AgentId | 企微管理后台 > 应用管理 |
WECOM_SECRET |
应用Secret | 企微管理后台 > 应用管理 |
WECOM_TOKEN |
回调Token | 企微管理后台 > 接收消息 |
WECOM_ENCODING_AES_KEY |
回调AES密钥 | 企微管理后台 > 接收消息 |
POSTGRES_PASSWORD |
数据库密码 | 自定义强密码 |
5. 启动服务
bash scripts/deploy.sh
这会自动执行:检查前置条件 → 构建后端镜像 → 启动所有容器
6. 验证部署
# 检查容器状态
docker compose ps
# 健康检查
curl http://localhost:18080/itdesk/health
# 查看 H5 员工端
curl -I http://localhost:18080/itdesk/
# 查看坐席工作台
curl -I http://localhost:18080/itagent/
# 查看后端 API
curl http://localhost:18080/api/docs
浏览器验证:
| 地址 | 预期 |
|---|---|
http://it-dataquery.dc.servyou-it.com/itdesk/ |
H5 员工咨询页面 |
http://it-dataquery.dc.servyou-it.com/itagent/ |
坐席工作台登录页 |
http://it-dataquery.dc.servyou-it.com/ |
IT 数据查询平台(不变) |
http://it-dataquery.dc.servyou-it.com/api/docs |
FastAPI Swagger 文档 |
两种网络接入方式
方式 A:数据平台 nginx 反代到本项目 nginx(推荐)
数据平台的 nginx 配置添加:
# IT 智能服务台路由
location /itdesk/ {
proxy_pass http://wecom_it_nginx:80/itdesk/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
location /itagent/ {
proxy_pass http://wecom_it_nginx:80/itagent/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
location /api/ {
proxy_pass http://wecom_it_nginx:80/api/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
location /ws/ {
proxy_pass http://wecom_it_nginx:80/ws/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
此方式下本项目 nginx 不暴露 80 端口,docker-compose.yml 的 ports 可以删除。
方式 B:本项目 nginx 直接监听 80 端口
如果数据平台没有自己的 nginx,或者想用本项目的 nginx 统一管理:
- 停止数据平台的端口映射
- 本项目 nginx 的 80 端口直接对外
- nginx.conf 中的
location /反代到数据平台容器
常见问题
Q: nginx 启动失败,报 host not found in upstream "dataquery"
A: nginx/nginx.conf 中的 DATAQUERY_HOST 未替换为数据平台实际 IP。编辑 nginx.conf,将占位符改为实际 IP:端口。
Q: 访问 /itdesk/ 返回 404
A: 检查前端 dist 是否正确挂载:
docker exec wecom_it_nginx ls -la /usr/share/nginx/html/itdesk/
Q: API 返回 CORS 错误
A: 检查 .env 中的 CORS_ORIGINS 是否包含 http://it-dataquery.dc.servyou-it.com
Q: 数据库迁移失败
A: 查看 backend 日志:
docker compose logs backend
如果 PostgreSQL 未就绪,等 30 秒后重启 backend:
docker compose restart backend
更新部署
只需更新变更的部分:
# 仅更新前端
bash scripts/deploy.sh --build
docker compose restart nginx
# 仅更新后端
docker compose build backend
docker compose up -d backend
# 全量更新
bash scripts/deploy.sh --down
bash scripts/deploy.sh