跳到主要内容

对话入口与生命周期管理

这部分是整个系统的"大门",一个对话请求从前端发过来,系统怎么接住它、怎么管理它从生到死的整个过程,都在这里。

整体流程概览

一个对话请求的生命周期大致是这样的:

  1. Controller 接收 SSE 请求
  2. 构建启动计划(参数校验、文档解析)
  3. 抢占 Redis 分布式租约(防并发)
  4. 引导会话(创建交换记录、注册任务)
  5. 绑定客户端通道(Reactor Sink → Flux)
  6. 激活生成(启动租约续期、订阅执行流)
  7. 执行完成/失败/停止 → 归档 → 清理资源
核心设计思路

整个流程用了"租约 + 注册表"双重保护:Redis 租约防止集群级别的并发冲突,JVM 注册表防止单机级别的重复处理。两层加在一起,确保同一个会话在同一时刻只有一个节点在处理。

Controller 层

BusinessChatController

包路径: org.javaup.ai.chatagent.controller

这是对话相关的所有 HTTP 接口入口。

方法路径说明
stream()POST /api/chat/streamSSE 流式对话主入口,返回 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的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠