SpringAI做对了什么
开发|界面|引擎|交付|副驾——重写全栈法则:AI原生的倍速造应用流
你好,这里是nine[谈架构]系列。
欢迎关注评论私信交流~

SpringAI 在 AI 编程领域延续了Spring的诸多优势,从易于集成、到通用API设计进行模型切换等。

SpringAI为什么好用
1. 易于集成
- Spring 生态系统:基于 Spring Boot 构建,继承了其强大的依赖注入、自动配置和应用启动特性。
- 无缝集成:可以轻松地与其他 Spring 项目(如 Spring Data, Spring Cloud)结合使用,形成完整的解决方案。
2. 丰富的模型支持
- 多平台支持:支持多种主流 AI 平台(如 OpenAI, Hugging Face, IBM Watson 等),满足不同用户的需求。
- 灵活扩展:用户可以根据需要添加新的 AI 模型或服务,只需遵循现有的模块化设计模式。
3. 高效的开发体验
- 自动配置:通过 Spring Boot 的自动配置机制,减少了繁琐的手动配置工作。
- 文档齐全:提供了详尽的文档和示例代码,帮助开发者快速上手。
4. 性能优化
- 批处理支持:部分模型支持批量处理请求,提高了处理效率。
- 重试机制:引入了
spring-ai-retry模块,增强了系统的容错能力,确保在不稳定网络环境下也能稳定运行。
5. 社区支持
- 活跃社区:作为 Spring 官方项目的一部分,拥有庞大的开发者社区和丰富的资源支持。
- 持续更新:定期发布新版本,修复 bug 并引入新特性,保持项目的活力和竞争力。
从SpringAI源码看设计
1. 模块化设计
-
核心模块 (
spring-ai-core):- 提供了 AI 编程的核心领域模型和接口。
- 包含了如
Document,EmbeddingModel,ChatClient等基础类。 - 定义了通用的工具类和辅助函数。
-
模型支持模块:
- 每个 AI 模型(如 Ollama, WatsonX, Bedrock, QianFan 等)都有独立的模块。
- 这些模块依赖于
spring-ai-core,并实现了特定 AI 服务的客户端和配置。 - 例如,
spring-ai-ollama模块提供了对 Ollama 模型的支持,并集成了 Jackson 库用于 JSON 处理。
-
向量存储模块:
- 支持多种向量数据库(如 Elasticsearch, Cassandra, MongoDB, Pinecone 等)。
- 提供了统一的 API 来与这些数据库进行交互,方便用户选择合适的存储方案。
-
文档读取器模块:
- 包含了 PDF、Markdown 和 Tika 文档读取器,用于处理不同格式的文本文件。
- 提供了灵活的配置选项,以适应不同的应用场景。
-
自动配置模块 (
spring-ai-spring-boot-autoconfigure):- 利用 Spring Boot 的自动配置机制,简化了应用程序的初始化过程。
- 提供了针对不同 AI 模型和服务的自动配置类,减少了用户的配置负担。
2. 依赖管理
- 使用 Maven 进行依赖管理,确保所有子模块共享相同的版本控制。
- 通过 BOM(Bill of Materials)文件统一管理依赖版本,避免版本冲突。
- 引入了诸如 Jackson、Micrometer、JUnit 等常用库,增强了项目的可扩展性和测试能力。
3. 配置灵活性
- 提供了丰富的配置属性,允许用户自定义 AI 模型的行为。
- 例如,
BedrockTitanEmbeddingProperties类允许用户配置 Titan Embedding 模型的启用状态、模型名称和输入类型。
4. 集成测试
- 各个模块都包含了详细的单元测试和集成测试,确保功能的正确性。
- 使用了 Testcontainers 和 Docker Compose 来模拟外部服务(如 Redis、Elasticsearch 等),提高了测试环境的真实性和可靠性。
案例
其他类似的框架还有:
- hncboy/ai-beehiveAI 蜂巢,基于 Java 使用 Spring Boot 3 和 JDK 17,支持的功能有 ChatGPT、OpenAi Image、Midjourney、NewBing、文心一言等等。
- alibaba/spring-ai-alibaba整合阿里生态基于SpringAI开发的框架。
更多使用demo可以查看 ThomasVitale/llm-apps-java-spring-ai
。该项目提供了文本、语音、向量库等相关模型的集成示例。
相关文章:
SpringAI做对了什么
开发|界面|引擎|交付|副驾——重写全栈法则:AI原生的倍速造应用流 你好,这里是nine[谈架构]系列。 欢迎关注评论私信交流~ SpringAI 在 AI 编程领域延续了Spring的诸多优势,从易于集成、到通用…...
DeepSeek预测25考研分数线
25考研分数马上要出了。 目前,多所大学已经陆续给出了分数查分时间,综合往年情况来看,每年的查分时间一般集中在2月底。 等待出成绩的日子,学子们的心情是万分焦急,小编用最近爆火的“活人感”十足的DeepSeek帮大家预…...
C++笔记之标准库中的std::copy 和 std::assign 作用于 std::vector
C++笔记之标准库中的std::copy 和 std::assign 作用于 std::vector code review! 文章目录 C++笔记之标准库中的std::copy 和 std::assign 作用于 std::vector1. `std::copy`1.1.用法1.2.示例2.`std::vector::assign`2.1.用法2.2.示例3.区别总结4.支持assign的容器和不支持ass…...
文件IO(20250217)
1. 文件IO 系统调用Linux内核提供的文件操作接口 1. 打开文件 open 2. 读写文件 read/write 3. 关闭文件 close 1.1 open函数 #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h>int open(const char *pathname, int flags); int ope…...
Django5 实用指南(四)URL路由与视图函数
4.1 Django5的URL路由系统 Django 的 URL 路由系统是其核心组件之一,它负责将用户的 HTTP 请求(即 URL)映射到相应的视图函数上。每当用户在浏览器中访问某个 URL 时,Django 会根据项目的 URL 配置文件(urls.py&#…...
Android 14输入系统架构分析:图解源码从驱动层到应用层的完整传递链路
一、资料快车 1、深入了解Android输入系统:https://blog.csdn.net/innost/article/details/47660387 2、书籍 - Android系统源代码情景分析 二、Perface 1、参考: 2、系统程序分析方法 1)加入log,并跟着log一步步分析 -logc…...
Java中Map循环安全的删除数据的4中方法
文章目录 前言一、使用Iterator删除二、使用 removeIf(Java 8)三、遍历时记录需要删除的键(不推荐)四、使用 Stream(Java 8)总结 前言 在 Java 中,遍历 HashMap 并删除数据时,直接使…...
蓝桥杯(B组)-每日一题(1093字符逆序)
c中函数: reverse(首位置,尾位置) reverse(s.begin(),s.end()) 头文件:<algorithm> #include<iostream> #include<algorithm>//运用reverse函数的头文件 using namespace std; int main() {string s;//定义一…...
【数据分析】3 数据分析成长之路
职业发展路径: 向上发展(技术方向):可以详细说明成为数据科学家或专家所需的具体技能和步骤,包括学习的算法、工具等。向下发展(业务方向):可以探讨结合业务知识的具体领域ÿ…...
循环神经网络RNN原理与优化
目录 前言 RNN背景 RNN原理 上半部分:RNN结构及按时间线展开图 下半部分:RNN在不同时刻的网络连接和计算过程 LSTM RNN存在的问题 LSTM的结构与原理 数学表达层面 与RNN对比优势 应用场景拓展 从简易但严谨的代码来看RNN和LSTM RNN LSTM 前言 绕循环神经…...
Python正则表达式处理中日韩字符过滤全解析
Python正则表达式处理中日韩字符过滤全解析 一、核心原理:Unicode字符范围定位 中日韩字符在Unicode中的分布: 中文:\u4e00-\u9fff(基本区) \u3400-\u4dbf(扩展A区) \U00020000-\U0002a6df…...
Zabbix 7.2实操指南:基于OpenEuler系统安装Zabbix 7.2
原文出处:乐维社区 部署环境 openEuler 22.03 LTS PHP 8.0 Apache Mysql 8.0 MySQL数据库 6.0 以上版本需要安装mysql8.0以上版本的数据库(以mysql为例子)。 欧拉系统自带 mysql8.0 的源,无需要安装额外的源。 安装mysql …...
扩展阅读-Elasticsearch 通过索引阻塞实现数据保护深入解析
目录 前言 1、索引阻塞的种类 2、什么时候使用阻塞? 场景1:进行系统维护场景。 场景2:保护数据不被随意更改场景。 场景3:优化资源使用的场景。 场景4:遵守安全规则场景。 3、添加索引阻塞API 4、解除设置 AP…...
SpringMVC重定向接口,参数暴露在url中解决方案!RedirectAttributes
OK,首先描述下业务场景,终端数量限制登录 1.首先访问项目login的get接口 2.输入账号密码点击登录后,会请求login的POST接口 3.后台对终端数量逻辑处理不允许登录跳回到登录页面 4.因代码原因需在后台进行多次重定向接口,最后跳…...
硬件学习笔记--46 电能表影响量试验梳理
目录 1.电流和电压电路中的谐波影响试验 1)电流和电压电路中谐波——第5次谐波试验 2)电流和电压电路中谐波——方顶波波形试验 3)电流和电压电路中谐波——尖顶波波形试验 4)电流和电压电路中谐…...
大数据技术之HBase操作归纳
HBase基本命令总结表(实际操作方式) 进入Hbase:hbase shell 方式一:命令行窗口来操作HBase 1.通用性命令 version 版本信息 status 查看集群当前状态 whoami 查看登入者身份 help 帮助2.HBase DDL操作(对象级操作) 2.1、namespace命名空间(相当…...
后端Java Stream数据流的使用=>代替for循环
API讲解 对比 示例代码对比 for循环遍历 package cn.ryanfan.platformback.service.impl;import cn.ryanfan.platformback.entity.Algorithm; import cn.ryanfan.platformback.entity.AlgorithmCategory; import cn.ryanfan.platformback.entity.DTO.AlgorithmInfoDTO; im…...
遗传算法与深度学习实战系列,自动调优深度神经网络和机器学习的超参数
遗传算法与深度学习实战系列文章 目录 进化深度学习生命模拟及其应用生命模拟与进化论遗传算法中常用遗传算子遗传算法框架DEAPDEAP框架初体验使用遗传算法解决N皇后问题使用遗传算法解决旅行商问题使用遗传算法重建图像遗传编程详解与实现粒子群优化详解与实现协同进化详解与…...
体验用ai做了个python小游戏
体验用ai做了个python小游戏 写在前面使用的工具2.增加功能1.要求增加视频作为背景。2.我让增加了一个欢迎页面。3.我发现中文显示有问题。4.我提出了背景修改意见,欢迎页面和结束页面背景是视频,游戏页面背景是静态图片。5.提出增加更多游戏元素。 总结…...
谷粒商城—分布式高级②.md
认证服务 1. 环境搭建 创建gulimall-auth-server模块,导依赖,引入login.html和reg.html,并把静态资源放到nginx的static目录下 2. 注册功能 (1) 验证码倒计时 //点击发送验证码按钮触发下面函数 $("#sendCode").click(function () {//如果有disabled,说明最近…...
GPT-5.5震撼发布!编码、科研能力全面飙升,OpenAI引领AI新纪元!
OpenAI于2026年4月23日正式发布了GPT-5.5模型,被誉为“迄今为止最聪明、最直观使用的模型”。GPT-5.5在编码、计算机使用、知识工作和科学研究四个核心领域实现显著升级,同时保持与GPT-5.4相同的推理延迟。该模型能更快理解用户意图,自主承担…...
完全开源的语言模型学习记录--TrilinearCIM架构
文章目录在这里插入图片描述一、一段话总结二、思维导图三、详细总结1. 研究动机与问题2. 核心技术方案3. 评估与结果4. 贡献与结论四、关键问题与答案https://arxiv.org/pdf/2604.07628 Trilinear Compute-in-Memory Architecture for Energy-Efficient Transformer Accelerat…...
Kubernetes 实战对比:ReplicationController 与 Deployment 核心差异+落地案例
Kubernetes 实战对比:ReplicationController 与 Deployment 核心差异落地案例 一、前言:从案例看控制器选择的重要性 在 Kubernetes 部署实践中,控制器的选择直接影响应用的稳定性和运维效率。本文通过 3 个真实业务场景,结合命令…...
多智能体强化学习环境PettingZoo:从AEC/并行API到实战应用
1. 项目概述:从单智能体到多智能体的跃迁 如果你是从OpenAI Gym或者Gymnasium一路玩过来的强化学习爱好者,那么当你第一次尝试把研究兴趣扩展到多个智能体时,大概率会感到一阵头疼。单智能体环境里, env.reset() 、 env.step(…...
AI分子对接
一、蛋白互作的生物学意义蛋白质-蛋白质相互作用(Protein-Protein Interactions, PPIs)在生物体内具有极其重要的生物学意义,主要体现在以下几个方面:(1)细胞信号传导。细胞通过受体蛋白与信号分子结合&…...
AudioSep音频分离终极指南:用自然语言描述分离任何声音
AudioSep音频分离终极指南:用自然语言描述分离任何声音 【免费下载链接】AudioSep Official implementation of "Separate Anything You Describe" 项目地址: https://gitcode.com/gh_mirrors/au/AudioSep 你是否曾为从嘈杂录音中提取清晰人声而烦…...
Elasticsearch-Kopf核心功能解析:集群监控、索引管理与快照备份全攻略
Elasticsearch-Kopf核心功能解析:集群监控、索引管理与快照备份全攻略 【免费下载链接】elasticsearch-kopf web admin interface for elasticsearch 项目地址: https://gitcode.com/gh_mirrors/el/elasticsearch-kopf Elasticsearch-Kopf是一款功能强大的El…...
大气层Atmosphere 1.7.1深度优化指南:终极性能调优与稳定配置
大气层Atmosphere 1.7.1深度优化指南:终极性能调优与稳定配置 【免费下载链接】Atmosphere-stable 大气层整合包系统稳定版 项目地址: https://gitcode.com/gh_mirrors/at/Atmosphere-stable 大气层Atmosphere-stable 1.7.1作为Switch系统破解的稳定版本&…...
如何将酷我音乐KWM格式转换为MP3?详细步骤与工具推荐
为什么酷我KWM格式需要转换 你是否遇到过这样的情况:在酷我音乐下载了喜欢的歌曲,却发现文件格式是KWM,既不能在其他音乐播放器打开,也无法传输到手机或U盘中播放?这是因为KWM是酷我音乐的加密格式,仅支持…...
GoWxDump:如何快速实现微信聊天记录的深度取证分析?
GoWxDump:如何快速实现微信聊天记录的深度取证分析? 【免费下载链接】GoWxDump 删库 项目地址: https://gitcode.com/gh_mirrors/go/GoWxDump 在数字化时代,社交媒体数据已成为数字取证领域的重要证据来源。微信作为中国最主流的即时通…...
