对话入口与生命周期管理
这部分是整个系统的"大门",一个对话请求从前端发过来,系统怎么接住它、怎么管理它从生到死的整个过程,都在这里。
整体流程概览
一个对话请求的生命周期大致是这样的:
- Controller 接收 SSE 请求
- 构建启动计划(参数校验、文档解析)
- 抢占 Redis 分布式租约(防并发)
- 引导会话(创建交换记录、注册任务)
- 绑定客户端通道(Reactor Sink → Flux)
- 激活生成(启动租约续期、订阅执行流)
- 执行完成/失败/停止 → 归档 → 清理资源
核心设计思路
整个流程用了"租约 + 注册表"双重保护:Redis 租约防止集群级别的并发冲突,JVM 注册表防止单机级别的重复处理。两层加在一起,确保同一个会话在同一时刻只有一个节点在处理。
Controller 层
BusinessChatController
包路径: org.javaup.ai.chatagent.controller
这是对话相关的所有 HTTP 接口入口。
| 方法 | 路径 | 说明 |
|---|---|---|
stream() | POST /api/chat/stream | SSE 流式对话主入口,返回 text/event-stream |
stop() | POST /api/chat/session/stop | 停止当前正在生成的回答 |
session() | POST /api/chat/session/detail | 获取会话详情 |
sessions() | POST /api/chat/session/list | 分页查询会话列表 |
reset() | POST /api/chat/session/reset | 重置会话(清空历史) |
exchange() | POST /api/chat/exchange/detail | 获取单次问答的详细信息 |
documentOptions() | POST /api/chat/document/options | 获取可选的知识文档列表 |
rebuildSummary() | POST /api/chat/session/summary/rebuild | 重建会话记忆摘要 |
retrievalResults() | POST /api/chat/exchange/retrieval/results | 查看检索观测结果 |
channelExecutions() | POST /api/chat/exchange/channel/executions | 查看通道执行记录 |
stageBenchmarks() | POST /api/chat/stage/benchmarks | 查看各阶段性能基准 |
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的详细文档
- 讲解视频:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
