执行前准备流程(五步决策链)
用户的问题进来之后,系统不会直接丢给大模型去回答。在真正执行之前,有一个"准备阶段",它会做一系列决策:该不该改写问题?该去哪个知识库找?该用什么模式回答?这些决策串起来就是所谓的"五步决策链"。
为什么要有这个阶段
直接把用户问题丢给大模型,效果往往不好。用户的问题可能指代不清、可能需要拆分、可能该去特定文档里找答案。准备阶段就是在"想清楚怎么回答"之后再动手。
总编排器
ChatPreparationOrchestrator
包路径: org.javaup.ai.chatagent.rag.service
这是准备阶段的总入口,只有一个对外方法,但内部逻辑很丰富。
| 方法 | 返回值 | 说明 |
|---|---|---|
prepare(TaskInfo) | ConversationExecutionPlan | 五步决策链的总入口,返回最终执行计划 |
prepare() 内部流程
按顺序执行以下步骤:
第一步:记忆加载
- 调用
summarizeHistory()→ 委托给ConversationMemoryService.loadMemoryContext() - 加载长期摘要 + 最近几轮原文
- 提取结构化规划上下文(目标、稳定事实、待解决问题、检索提示)
第二步:时间敏感性检测
- 判断问题是否需要当前日期锚定(比如"今天天气怎么样")
- 判断是否需要实时搜索
第三步:模式分发
- 如果是
OPEN_CHAT模式 → 直接返回REACT_AGENT执行计划 - 如果是
DOCUMENT或AUTO_DOCUMENT模式 → 继续后续步骤
第四步:问题改写与知识路由
- 调用
ChatQueryRewriteService.rewrite()改写问题 - 如果是
AUTO_DOCUMENT模式,调用KnowledgeRouteService.route()选择目标文档 - 如果路由结果模糊,可能触发
CLARIFICATION模式(反问用户)
第五步:文档问题路由
- 调用
DocumentQuestionRouter.route()判断执行模式 - 最终组装
ConversationExecutionPlan返回
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的详细文档
- 讲解视频:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
