简介 :: Spring AI 中文文档

Spring AI 解决了 AI 集成的根本难题:将企业数据和 API 与 AI 模型连接起来。

聊天客户端 API (ChatClient )

发起对模型的调用和响应

  1. 创建:其中可以通过bean来注入创建好的chatClient
    可以使用@Qualifier注解,使用多模型,创建多chatClient
  2. ChatClient 响应
    1. 多种格式,包括flux
  1. 提示模板
    TemplateRenderer 作为模板引擎
  2. call返回值: 返回相应对象或字符串
  3. stream返回值:多种flux对象
  4. advisor
    1. Advisor API 为 Spring 应用中的 AI 驱动交互提供灵活强大的拦截、修改和增强能力。
interface AdvisorSpec {AdvisorSpec param(String k, Object v);AdvisorSpec params(Map<String, Object> p);AdvisorSpec advisors(Advisor... advisors);AdvisorSpec advisors(List<Advisor> advisors);
}
ChatClient.builder(chatModel).build().prompt().advisors(MessageChatMemoryAdvisor.builder(chatMemory).build(),QuestionAnswerAdvisor.builder(vectorStore).build()).user(userText).call().content();
  1. 聊天记忆:
    ChatMemory 接口定义了聊天对话存储机制,当前内置实现MessageWindowChatMemory, 包括jdbc在内的多种存储方案

Advisor API

执行流程
 

  1. 实现示例,定义一个LoggerAdvisor
public class SimpleLoggerAdvisor implements CallAroundAdvisor, StreamAroundAdvisor {@Overridepublic AdvisedResponse aroundCall(AdvisedRequest advisedRequest, CallAroundAdvisorChain chain) {logger.debug("BEFORE: {}", advisedRequest);AdvisedResponse advisedResponse = chain.nextAroundCall(advisedRequest);logger.debug("AFTER: {}", advisedResponse);return advisedResponse;}@Overridepublic Flux<AdvisedResponse> aroundStream(AdvisedRequest advisedRequest, StreamAroundAdvisorChain chain) {logger.debug("BEFORE: {}", advisedRequest);Flux<AdvisedResponse> advisedResponses = chain.nextAroundStream(advisedRequest);return new MessageAggregator().aggregateAdvisedResponse(advisedResponses,advisedResponse -> logger.debug("AFTER: {}", advisedResponse)); }
}

Prompt

  1. 主要角色
System 角色:指导 AI 的行为和响应风格,设定 AI 解释和回复输入的参数或规则,类似于在开始对话前向 AI 提供指令。
User 角色:代表用户的输入 — 包括问题、命令或对 AI 的陈述。该角色构成 AI 响应的基础,具有根本重要性。
Assistant 角色:AI 对用户输入的响应,不仅是答案或反应,更对维持对话流至关重要。通过追踪 AI 之前的响应(其 "Assistant Role" 消息),系统确保连贯且上下文相关的交互。助手消息也可能包含函数工具调用请求信息 — 这是 AI 的特殊功能,在需要时执行计算、获取数据等超越对话的特定任务。
Tool/Function 角色:专注于响应工具调用类助手消息,返回附加信息。

PromptTemplate

PromptTemplate promptTemplate = PromptTemplate.builder().renderer(StTemplateRenderer.builder().startDelimiterToken('<').endDelimiterToken('>').build()).template("""Tell me the names of 5 movies whose soundtrack was composed by <composer>.""").build();String prompt = promptTemplate.render(Map.of("composer", "John Williams"));
PromptTemplate promptTemplate = new PromptTemplate("Tell me a {adjective} joke about {topic}");
Prompt prompt = promptTemplate.create(Map.of("adjective", adjective, "topic", topic));
return chatModel.call(prompt).getResult();

TOOlS

  1. 示例
class DateTimeTools {@Tool(description = "Get the current date and time in the user's timezone")String getCurrentDateTime() {return LocalDateTime.now().atZone(LocaleContextHolder.getTimeZone().toZoneId()).toString();}@Tool(description = "Set a user alarm for the given time, provided in ISO-8601 format")void setAlarm(String time) {LocalDateTime alarmTime = LocalDateTime.parse(time, DateTimeFormatter.ISO_DATE_TIME);System.out.println("Alarm set for " + alarmTime);}}ChatModel chatModel = ...
String response = ChatClient.create(chatModel).prompt("Can you set an alarm 10 minutes from now?").tools(new DateTimeTools()).call().content();System.out.println(response);

  1. 创建tools的两种方式, tools注解,和通过MethodToolCallback的编程式配置

MCP

  1. mcp client

  2. mcp server

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/89204.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/89204.shtml
英文地址,请注明出处:http://en.pswp.cn/web/89204.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于SD-WAN的智慧高速解决方案:高效、低成本的智能交通实践

随着交通网络的智能化需求逐渐增加&#xff0c;智慧高速建设已成为提升通行效率、优化安全性、实现交通现代化管理的重要方向。在本文中&#xff0c;我们将以某智慧高速项目为例&#xff0c;详细探讨如何通过 SD-WAN 技术与多种智能化手段结合&#xff0c;实现“低成本、高效率…

Towards Low Light Enhancement with RAW Images 论文阅读

利用 RAW 图像实现低光增强 摘要 在本文中&#xff0c;我们首次进行了基准研究&#xff0c;详细阐述了在低光增强中使用 RAW 图像的优越性&#xff0c;并提出了一种新颖的替代方案&#xff0c;以更灵活和实用的方式利用 RAW 图像。受对典型图像处理流程的全面考虑启发&#xff…

smolagents - 如何在mac用agents做简单算术题

smolagent是hf推出的agent开发库&#xff0c;简洁易用。这里尝试用smolagents完成简单数学题目。 1 smolagents安装 conda create -n smolagents python3.12 conda activate smolagents pip install smolagents pip install smolagents[mlx-lm] 由于是在mac使用mlx&#xff0c;…

【无标题】LighthouseGS:面向全景式移动拍摄的室内结构感知三维高斯泼溅

标题&#xff1a;<LighthouseGS: Indoor Structure-aware 3D Gaussian Splatting for Panorama-Style Mobile Captures> 论文&#xff1a;https://arxiv.org/pdf/2507.06109 来源&#xff1a;南京大学&#xff1b;复旦大学&#xff1b;华为诺亚实验室 文章目录摘要一、前…

el-table中type=“selection“选中数据如何回显

效果如下代码如下 关键函数&#xff1a;toggleRowSelection(this.tableData[i])设置默认选中数据。 <template><el-tableref"multipleTable":data"tableData"tooltip-effect"dark"style"width: 100%"selection-change"h…

为来时路,OCM拿证学习和考试

为何选择OCM&#xff1f;OCM的含金量无需多言。全球持证人数不足万人&#xff0c;中国地区更是寥寥千人。它不仅是技术实力的象征&#xff0c;更是通往金融、互联网、通信等核心企业高薪岗位的“通行证”。据行业数据显示&#xff0c;持有OCM认证的技术人员&#xff0c;薪资普遍…

beautiful-react-hooks库——入门实践常用hook详解

简介 beautiful-react-hooks 是一个专为 React 设计的高质量自定义 Hooks 集合&#xff0c;涵盖了事件、状态、生命周期、DOM 操作、性能优化等多个方面&#xff0c;极大提升了函数组件的开发效率和代码复用性。 安装方法 npm install beautiful-react-hooks # 或 yarn add …

DOM 规范中的 MutationObserver 接口

MutationObserver 接口DOM规范中的 MutationObserver 接口可以在DOM被修改时异步执行回调。使用MutationObserver可以观察整个文档、DOM树的一部分或某个元素&#xff0c;元素属性、字节点、文本等。新引进的MutationObserver接口取代了已废弃的MutationEvent。MutationObserve…

3.7 小结

图3-7-1点云可视化点云可视化工具就像是打开点云数据宝藏大门的钥匙&#xff0c;能让我们直观地理解和分析这些复杂的数据。本章节&#xff0c;主要介绍了PCL、Open3D、Matplotlib、PCShow、VTK 这几种点云可视化工具。PCL&#xff08;Point Cloud Library&#xff09;是专注于…

对称二叉树、二叉树直径

101. 对称二叉树 - 力扣&#xff08;LeetCode&#xff09; 法一&#xff1a;递归。 对于两个对称位置的节点L和R&#xff08;L在左子树&#xff0c;R在右子树&#xff09;&#xff0c;只有当L的左节点值R的右节点值且L的右节点值R的左节点值时&#xff0c;这棵二叉树才有可能对…

Java多线程1

线程是操作系统能够运行调度的最小单位&#xff0c;它包含在进程之中&#xff0c;是进程的实际运作单位多线程有三种实现方式线程实现方法1&#xff0c;继承Thread类&#xff08;无返回值&#xff09;&#xff1a;1、继承Thread2、重写run方法&#xff08;线程要执行的代码&…

云计算如何提高企业的数据安全性和隐私保护

在企业数字化转型加速推进的今天&#xff0c;数据安全与隐私保护已成为决定企业生存发展的核心命题。云计算凭借其灵活的架构优势&#xff0c;不仅重塑了企业资源管理模式&#xff0c;更在数据安全防护领域构建起多层次保障体系。以下从六大维度解析云计算如何为企业数据安全与…

GaussDB 数据库架构师修炼(二)数据库计算容量评估

1 计算资源容量评估主要流程 一般地是经过以下5个流程评估GaussDB的计算容量: 2 TPC-C基准测试介绍 1)TPC-C是业界常用的一套Benchmark 由TPC (Transaction Processing Performance Council)委员会制定发布,用于 评测数据库的联机交易处理(偏向OLTP)能力,测试结果数据…

开源 python 应用 开发(六)网络爬虫

最近有个项目需要做视觉自动化处理的工具&#xff0c;最后选用的软件为python&#xff0c;刚好这个机会进行系统学习。短时间学习&#xff0c;需要快速开发&#xff0c;所以记录要点步骤&#xff0c;防止忘记。 链接&#xff1a; 开源 python 应用 开发&#xff08;一&#xf…

flink sql读hive catalog数据,将string类型的时间戳数据排序后写入kafka,如何保障写入kafka的数据是有序的

在 Flink SQL 中&#xff0c;要确保从 Hive 读取的 STRING 类型时间戳数据排序后有序写入 Kafka&#xff0c;需要结合 批处理模式、时间类型转换、单分区写入 和 Kafka 生产者配置。以下是完整解决方案&#xff1a; 一、核心解决方案 1. 批处理模式 全局排序 将作业设置为批处…

7.17 滑动窗口 |assign |memo

lcp56. memo优化tle或者改用bfsclass Solution {int m, n;int dx[4] {0, 0, 1, -1};int dy[4] {1, -1, 0, 0};public:int conveyorBelt(vector<string>& matrix, vector<int>& start, vector<int>& end) {int ret INT_MAX;m matrix.size();n…

统计功效是什么?

统计功效的通俗理解可以把“统计功效”想象成侦探破案的能力——它代表统计检验&#xff08;侦探&#xff09;在犯罪事实确实存在&#xff08;真实效应存在&#xff09;时&#xff0c;成功发现真相&#xff08;检测出效应&#xff09;的概率。核心比喻假设你是一个侦探&#xf…

大语言模型(LLM)训练的教师强制(Teacher Forcing)方法

大语言模型&#xff08;LLM&#xff09;在训练时使用一种名为“教师强制&#xff08;Teacher Forcing&#xff09;”的方法&#xff0c;而不是它们在推理&#xff08;生成文本&#xff09;时使用的“自回归&#xff08;Autoregressive&#xff09;”方法 。阐明关于LLM训练的一…

归一化与激活函数:深度学习的双引擎

归一化和激活函数区别 归一化和激活函数是深度学习中两个不同但又存在关联的技术,前者聚焦于“数据分布的调整”,后者聚焦于“引入非线性与输出转换”。 Softmax 既可以被视为一种归一化操作,也属于激活函数 因为它同时满足两者的核心特征,只是从不同角度定义:从“输出…

C# --- 单例类错误初始化 + 没有释放资源导致线程泄漏

C# --- 单例类错误初始化 没有释放资源导致线程泄漏Background原因分析问题一&#xff1a; 错误初始化&#xff08;使用了箭头函数&#xff09;问题一&#xff1a; 没有Dispose资源Background 背景: service A的其中一个Api会向mq发送消息问题&#xff1a;线上发现这个服务经常…