ai-robot-core/spec/intent-driven-script/solution-java-channel-side.md

201 lines
4.9 KiB
Markdown
Raw Normal View History

# AI客服智能体增强改造方案渠道侧 / Java
## 1. 改造定位
Java 渠道侧承担“用户体验与会话控制中枢”角色,核心职责:
- 分段消息发送(拟人化节奏)
- 打断处理(实时中断、无重复发送)
- 本地会话历史缓存(已送达真相)
- 全量消息异步上报(含人工阶段)
目标:让智能体能力在前端体验上可感知且可控。
---
## 2. 渠道侧总体设计
## 2.1 新增组件
1. `SegmentDispatcher`(消息调度器)
2. `InterruptManager`(打断管理器)
3. `DeliveredHistoryStore`(已送达历史存储)
4. `MessageReporter`(全量消息上报器)
5. `SessionModeManager`(机器人/人工状态管理)
## 2.2 会话状态机
- `BOT_ACTIVE`:机器人对话中
- `BOT_SENDING`:机器人分段发送中
- `INTERRUPTED`:发送被打断,等待新请求
- `HUMAN_ACTIVE`:人工接管
---
## 3. 核心流程设计
## 3.1 正常流程(无打断)
1. 用户消息进入渠道侧
2. 组装请求(`session_id + user_message + delivered_history`)调用中台
3. 收到 `segments[]`
4. `SegmentDispatcher``delay_after` 顺序发送
5. 每发送成功一段,写入 `DeliveredHistoryStore`
6. 异步上报每条消息(用户/机器人)
## 3.2 打断流程
1. 发送中收到新用户消息
2. `InterruptManager` 立即取消未发送段
3. 仅保留“已送达段”作为历史
4. 发起新请求,附带 `interrupted_segments`(可选)
5. 中台重新决策后返回新 `segments[]`
## 3.3 转人工流程
1. 渠道侧调用中台状态接口标记 `HUMAN_ACTIVE`
2. 后续消息不再调用智能体
3. 用户与人工消息继续异步上报中台(保证闭环数据)
---
## 4. 关键模块说明
## 4.1 SegmentDispatcher
职责:
- 顺序发送片段
- 尊重 `delay_after`
- 支持取消令牌(中断)
建议实现点:
- 每个 session 单独队列
- 每段发送前检查会话是否仍为 `BOT_SENDING`
- 失败重试最多 1 次(避免重复刷屏)
## 4.2 InterruptManager
职责:
- 监听用户新消息事件
- 取消当前发送任务
- 记录中断点(最后已送达 segment_id
建议规则:
- 中断优先级高于发送
- 丢弃未送达段,不做补发
## 4.3 DeliveredHistoryStoreRedis
建议键:`chat:{sessionId}:delivered`
建议字段:
- roleuser/assistant/human
- content
- timestamp
- segment_idassistant可选
- sourcebot/human
只存“已送达”消息,避免上下文污染。
## 4.4 MessageReporter
职责:
- 异步上报全量消息到中台历史服务
- 支持重试与死信队列
必须上报:
- 用户消息
- 机器人每个已送达段
- 人工客服消息
- 模式切换事件bot->human/human->bot
---
## 5. 请求与响应协议建议
## 5.1 渠道 -> 中台请求
```json
{
"session_id": "sess_123",
"user_message": "孩子五年级,数学不好",
"history": [
{"role": "user", "content": "你好"},
{"role": "assistant", "content": "您好"}
],
"interrupted_segments": [
{"segment_id": "seg_2", "content": "稍等,我查一下"}
]
}
```
## 5.2 中台 -> 渠道响应
```json
{
"segments": [
{"segment_id": "seg_3", "text": "好的,请问孩子具体是哪个知识点薄弱?", "delay_after": 800},
{"segment_id": "seg_4", "text": "比如分数应用题还是几何?", "delay_after": 0}
]
}
```
---
## 6. 与中台协同的关键约束
1. 渠道侧只认 `segments[]`,不关心中台内部是 agent 还是 flow。
2. 必须使用“已送达历史”回传,不能用“计划发送历史”。
3. 打断后立即重发,不等待旧请求自然结束。
4. 人工模式下继续上报,保证中台记忆与分析完整。
---
## 7. 可观测性指标(渠道侧)
建议上报指标:
- `segment_send_latency_ms`
- `segment_drop_count`(中断丢弃)
- `interrupt_count`
- `resend_request_count`
- `bot_to_human_switch_count`
- `history_report_success_rate`
日志关键字段:
- session_id
- request_id
- segment_id
- mode
- interrupted_at
---
## 8. 分阶段实施建议(渠道侧)
## Phase 1
- 实现分段发送 + 本地已送达历史
- 接入中台 `segments` 协议
## Phase 2
- 打断管理上线(实时取消 + 重新请求)
- 全量消息上报链路上线
## Phase 3
- 人工接管状态机完善
- 失败重试、幂等、死信治理完善
---
## 9. 风险与应对
1. 重复发送风险
- 通过 `segment_id + session_id` 做幂等去重
2. 中断竞态(旧包晚到)
-`request_id` / `generation_id` 校验,只消费最新响应
3. 历史错乱
- 仅以“已送达消息”入历史,不以“待发送消息”入历史
4. 上报积压
- 异步队列 + 批量上报 + 失败重试
---
## 10. 最终建议(渠道侧)
- 渠道侧的首要目标不是“更聪明”,而是“更稳定 + 更像人 + 可打断”。
- 只要分段、打断、历史上报三件事做稳,中台 Agent 的价值会显著放大。