spring ai alibaba原理源码分析(一)-架构

简介

spring ai alibaba是java的ai agent框架,本系列将深入剖析 Spring AI Alibaba 的源码实现与核心原理,不仅指导agent的开发,更为了改造框架,增加新特性

系列内容:

系列( 一) 架构 本文<<

系列( 二) agent&graph,分析ReactAgent/FlowAgent/a2a agent;StateGraph,CompiledGraph

系列( **三)**模型,钩子和拦截器;消息/结构化输出

系列( **四)**上下文工程,记忆

系列( 五) 调用 工具/MCP/skills/CLI

系列( 六) RAG

系列( 七) 可观测和评估

系列(八)多agent

工作流/agentic

系列(九) agent产品级示例解释 DataAgent

热点:agent发布,列表,提示词管理,评估,观测

关键词

Agent ReActAgent/FlowAgent

pipeline/agentic

flow/graph

缩写

spring ai缩写sa

spring ai alibaba 本文缩写saa

参考资料

https://java2ai.com/docs/overview spring ai alibaba官网文档

逻辑架构

上图是saa的逻辑架构图, 展示了 Spring AI Alibaba的整体架构层次,体现了"以 ReactAgent 为核心、Graph 为运行时基座"的设计。整个系统可划分为四个主要层级:

  • 用户角色层

业务人员: admin 提示词配置,观测,评估

开发人员: studio 提供chatui

  • 核心框架层(agent framework + graph)

agent framework:面向开发者的核心 API 层,提供高阶图形范式

graph-core:作为底层运行时引擎,承担工作流编排与状态管理职责:。

starter:自动配置。

  • spring ai扩展

扩展体系,覆盖 AI 应用关键能力域

  • Spring AI 生态

位于最底层,saa建立在spring ai生态上,代表框架所依赖的通用 AI 能力模块

组件视图

上图是saa原理源码分析场景视图,每个包对应着saa/sa组件或特性,是本文分析的目录

agent/graph agent和图紧密相关,可以认为agent是一种既定的"图"形,开发人员可以使用graph低层api直接构建graph,也可以使用agent,获得既定的图形

model sa对大模型的封装,模型包括Chat,嵌入,audio,image等类型

上下文工程/记忆(memory)

调用(calling) calling可能是agent发展演变最快的部分,最初的工具,到mcp,最近的CLI,skills

钩子和拦截器 saa的组件,钩子和拦截器不只是给用户嵌入逻辑,负责saa很多核心业务,是很重要的组件

评估 saa的模型评估不是基于sa的评估,而是自己的一套体系,构建了一个 数据集 -> 评估器 -> 实验 -> 报告的评估闭环

可观测 大模型自主性高,功能强,检测

消息/结构化输出

RAG

MAS 多个agent协同工作,每个agent有清晰而独立的智能

studio 简易的agent管理工具,嵌入到agent,带有agent面板,列表agent;提供chat界面,用于调试agent,是开发agent的便利工具

admin 作为管理台,有几个重量级的功能,agent的发布和列表,提示词管理,评估和数据集,观测值得分析

开发架构

本章以saa的agent示例DeepResearch分析saa的开发架构。

DeepResearch 分析用户输入,给出格式化研究报告。DeepResearch 是ReactAgent ,遵循思考,行动( 工具/MCP 调用) ,观测的循环迭代。

上图是DeepResearch 启动,agent内嵌了studio组件,打开http://localhost:8080/chatui/index.html,可看到agent面板,点击agent打开chatui,可与agent交互

关于MCP服务

示例使用mcp.jina.ai MCP 服务器,外部资料搜索的工具,可改为魔搭的bing搜索mcp服务

源码解释

本节解释agent源码,下图是类图,类互动图,蓝色类是DeepResearch,浅绿色是studio,橙色是其他包

DeepResearch是spring boot应用

AgentStaticLoader 标注@Component,spring boot扫描实例化,AgentStaticLoader负责new DeepResearchAgent,也为控制器服务,获取agent列表

DeepResearchAgent 虽然名字带agent,但不是真正的agent,没有继承Agent类,DeepResearchAgent负责构建agent,包括agent依赖的组件,model,hook和拦截器等(图上只展示部分的hook和拦截器)

DeepRearch 是真正的agent,是主agent,引用两个子agent

research-agent 负责搜集资料

critique-agent 负责评审生成的研究报告

ToolCallbackProvider 具调用提供者,本实例是MCP封装为工具,MCP将在系列 -" **调用"**分析

下面介绍几个实例用到的**++hook++** ++和拦截器++++hook++ **++和拦截器++**在agent框架是关键的组件,提供核心工具,如FilesystemInterceptor;推理规划,如TodoListInterceptor;维护上下文,如,SummarizationHook,hook和拦截器不仅仅给用户扩展,更是agent框架的提供核心功能

TodoListInterceptor 思考,生成todo清单

FilesystemInterceptor 供文件系统工具,提供`ls`, `read_file`, `write_file`, `edit_file`等文件操作,本实例,todo清单和生成的研究报告都写入文件

SubAgentInterceptor构建子agent,包装成工具

studio

studio是内置的web服务,主要功能是列表agent,与agent对话(chatui)

SaaStudioWebModuleAutoConfiguration studio包声明的自动配置类,spring boot调起,studio由此启动,同时,该类声明了@ComponentScan,扫描studio范围的spring对象

StudioLoaderAutoConfiguration 这个类实例化ContextScanningAgentLoader

ContextScanningAgentLoader 负责扫描上下文,使用ApplicationContext获取agent实例,但实例方法声明了@ConditionalOnMissingBean(AgentLoader.class),在DeepResearchAgent已经声明了AgentStaticLoader,ContextScanningAgentLoader没有实例化,设计有点奇怪,最初以为是扫描AgentLoader,然后获取agent bean

AgentController/ExecutionController 个处理web请求的控制器,列表agent,依赖AgentStaticLoader;执行agent

**总结:**agent的开发,包括model,工具(tool&mcp),钩子和拦截器,agent可以引用其他agent完成指定的任务,本实例还引用studio,提供agent的列表页面,对话。agent loader机制构建和初始Agent。

最后,还有最重要的角色未提及,上下文工程 ,大模型正确的工作关键是提示词,将在**++系列++** ++-++ **++上下文工程++**分析

运行

本节观测一下agent运行情况

agent首先todolist出任务规划,规划出6个任务

research agent利用搜索工具获取资料,返回主agent

critique-agent评估,返回主agent

主agent出报告,形成思考-工具调用(搜索)-评估的迭代闭环,最后生成研究报告

NEXT

系列( 二) agent&graph

相关推荐
AI医影跨模态组学17 分钟前
J Clin Oncol(IF=43.4)美国Cedars-Sinai医学中心等团队:基于计算组织学人工智能的晚期胰腺癌化疗选择预测性生物标志物的开发与验证
人工智能·机器学习·论文·医学·医学影像·影像组学
冬奇Lab33 分钟前
RAG 系列(十六):Graph RAG——用知识图谱解决多跳关系问题
人工智能·llm
冬奇Lab41 分钟前
一天一个开源项目(第101篇):OpenHuman - 真正懂你的本地优先个人 AI 超级助手
人工智能·开源·资讯
云上码厂1 小时前
专业的学术会议 / 讲座视频与幻灯片托管、回放平台(可以使用SlidesLive 学英语入门清单)
人工智能
无心水1 小时前
【Hermes:安全、权限与生产环境】40、运行 Hermes 前的生命线:安全审计清单与 11 个必须检查的配置项
人工智能·安全·mcp协议·openclaw·养龙虾·hermes·honcho
温九味闻醉1 小时前
关于腾讯广告算法大赛2025项目分析3-重读
人工智能·机器学习
十铭忘1 小时前
AI画架构图的方法
人工智能
chatexcel1 小时前
AI知识库教程:基于ChatExcel实现规则文档、Excel数据与业务分析联动
人工智能·excel
Hali_Botebie2 小时前
【图卷积网络】GCN是AXΘ 和CNN是AX
网络·人工智能·cnn
还在忙碌的吴小二2 小时前
今日AI行业热点新闻
人工智能