Spring AI 入門:Java 開發者的生成式 AI 實踐之路

?一、Spring AI 簡介

在人工智能技術快速迭代的今天,Spring AI 作為 Spring 生態系統的新生力量,正在成為 Java 開發者擁抱生成式 AI 的最佳選擇。該框架通過模塊化設計實現了與主流 AI 服務(如 OpenAI、Anthropic)的無縫對接,同時支持本地模型部署(如 Ollama),為開發者提供了靈活高效的 AI 集成方案。

?

?核心價值體現:

- 生態融合:完美繼承 Spring Boot 的自動配置特性,通過簡單配置即可接入 AI 服務

- 多模型支持:統一抽象層兼容 OpenAI GPT、Mistral 等 20+主流模型

- 企業級特性:內置重試機制、限流策略、監控指標等生產級功能

- 全棧能力:覆蓋文本生成、圖像處理、向量檢索等完整 AI 應用場景

?

?二、環境準備

?1. 開發環境要求

- JDK 17+(推薦 Azul Zulu JDK)

- Spring Boot 3.2.x

- Maven 3.8.6+ 或 Gradle 8.5+

?

?2. 項目初始化

通過 Spring Initializr 創建項目時選擇:

bash

Project: Maven Project

Language: Java

Spring Boot: 3.2.1

Dependencies: Spring Web, Spring AI Starter

?

?3. 依賴配置

在 `pom.xml` 中添加核心依賴:

xml

<dependency>

? ? <groupId>org.springframework.ai</groupId>

? ? <artifactId>spring-ai-starter</artifactId>

? ? <version>0.8.1</version>

</dependency>

<!-- OpenAI 服務支持 -->

<dependency>

? ? <groupId>org.springframework.ai</groupId>

? ? <artifactId>spring-ai-openai-spring-boot-starter</artifactId>

? ? <version>0.8.1</version>

</dependency>

?

?三、快速入門實踐

?1. 配置 API 密鑰

在 `application.yml` 中設置服務憑證:

yaml

spring:

? ai:

? ? openai:

? ? ? api-key: sk-your-api-key-here

? ? ? chat:

? ? ? ? options:

? ? ? ? ? model: gpt-3.5-turbo

? ? ? ? ? temperature: 0.7

?

?2. 創建聊天服務

java

@Service

public class ChatService {

? ??

? ? @Autowired

? ? private ChatClient chatClient;

?

? ? public String generateResponse(String prompt) {

? ? ? ? ChatResponse response = chatClient.call(prompt);

? ? ? ? return response.getResult().getOutput().getContent();

? ? }

}

?

?3. 控制器實現

java

@RestController

@RequestMapping("/api/chat")

public class ChatController {

? ??

? ? @Autowired

? ? private ChatService chatService;

?

? ? @GetMapping

? ? public String chat(@RequestParam String message) {

? ? ? ? return chatService.generateResponse(message);

? ? }

}

?

?4. 測試接口

通過 curl 發送請求:

bash

curl "http://localhost:8080/api/chat?message=用Java實現快速排序"

?

?四、核心功能解析

?1. 模型管理

Spring AI 提供統一的模型訪問接口:

java

@Autowired

private ModelManager modelManager;

?

// 加載本地模型

TensorFlowModel model = modelManager.loadModel("classpath:model.pb");

?

// 調用遠程服務

OpenAiChatOptions options = OpenAiChatOptions.builder()

? ? .withTemperature(0.5)

? ? .build();

?

?2. 提示工程

通過模板化提示提升輸出質量:

java

PromptTemplate template = new PromptTemplate("作為{role},請用{language}解釋{topic}");

template.addVariable("role", "資深架構師");

template.addVariable("language", "中文");

template.addVariable("topic", "微服務架構設計");

?

?3. 向量處理

文本向量化實現語義檢索:

java

TextEmbedding embedding = new OpenAiTextEmbedding();

float vector = embedding.embed("Spring AI 入門指南");

?

?4. RAG 增強

結合檢索增強生成技術:

java

RetrievalChain chain = RetrievalChain.builder()

? ? .withRetriever(vectorRetriever)

? ? .withPromptTemplate(promptTemplate)

? ? .build();

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/83834.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/83834.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/83834.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

優化電腦的磁盤和驅動器提高電腦性能和延長硬盤壽命?

磁盤優化 磁盤清理&#xff1a; 使用系統自帶的磁盤清理工具&#xff08;如Windows的“磁盤清理”&#xff09;刪除不必要的文件。清空回收站。刪除臨時文件和緩存。 磁盤碎片整理&#xff08;針對機械硬盤&#xff09;&#xff1a; 定期進行磁盤碎片整理&#xff0c;以提高文…

EDA斷供危機下的冷思考:中國芯片設計軟件的破局之道優雅草卓伊凡

EDA斷供危機下的冷思考&#xff1a;中國芯片設計軟件的破局之道優雅草卓伊凡 一、EDA是什么&#xff1f;芯片行業的”隱形基石” 1.1 EDA技術解析 EDA&#xff08;Electronic Design Automation&#xff0c;電子設計自動化&#xff09;是用于設計和驗證集成電路的軟件工具鏈…

Jpackage

簡介 jpackage - 用于打包自包含 Java 應用程序的工具&#xff0c;是 JDK 14 引入的一個工具。 該工具將 Java 應用程序和 Java 運行時映像作為輸入&#xff0c;并生成包含所有必要依賴項的 Java 應用程序映像。它將能夠生成特定于平臺的格式的本機包&#xff0c;例如包括打包 …

CRM管理軟件的數據可視化功能使用技巧:讓數據驅動決策

在當今數據驅動的商業環境中&#xff0c;CRM管理系統的數據可視化功能已成為企業優化客戶管理、提升銷售效率的核心工具。據企銷客研究顯示&#xff0c;具備優秀可視化能力的CRM系統&#xff0c;用戶決策效率可提升47%。本文將深入解析如何通過數據可視化功能最大化CRM管理軟件…

智慧充電:新能源汽車智慧充電樁的發展前景受哪些因素影響?

全球能源結構轉型與碳中和目標的推進&#xff0c;新能源汽車產業迎來爆發式增長&#xff0c;而智慧充電樁作為其核心基礎設施&#xff0c;發展前景備受關注。智慧充電不僅關乎用戶充電體驗的優化&#xff0c;更是電網平衡、能源效率提升的關鍵環節。 然而&#xff0c;其發展并…

ABAP設計模式之---“簡單設計原則(Simple Design)”

“Simple Design”&#xff08;簡單設計&#xff09;是軟件開發中的一個重要理念&#xff0c;倡導以最簡單的方式實現軟件功能&#xff0c;以確保代碼清晰易懂、易維護&#xff0c;并在項目需求變化時能夠快速適應。 其核心目標是避免復雜和過度設計&#xff0c;遵循“讓事情保…

多模態大語言模型arxiv論文略讀(105)

UnifiedMLLM: Enabling Unified Representation for Multi-modal Multi-tasks With Large Language Model ?? 論文標題&#xff1a;UnifiedMLLM: Enabling Unified Representation for Multi-modal Multi-tasks With Large Language Model ?? 論文作者&#xff1a;Zhaowei…

SQLServer中的存儲過程與事務

一、存儲過程的概念 1. 定義 存儲過程&#xff08;Stored Procedure&#xff09;是一組預編譯的 SQL 語句的集合&#xff0c;它們被存儲在數據庫中&#xff0c;可以通過指定存儲過程的名稱并執行來調用它們。存儲過程可以接受輸入參數、輸出參數&#xff0c;并且可以返回執行…

使用UDP連接ssh

使用UDP連接ssh mosh簡介兩端安裝moshWindows安裝mosh 放行端口使用mosh登錄Linuxdebug mosh簡介 Mosh最大的特點是基于UDP方式傳輸&#xff0c;支持在服務端創建一個臨時的Key供客戶端一次性連接&#xff0c;退出后失效&#xff1b;也支持通過SSH的配置進行認證&#xff0c;但…

軟件功能模塊歸屬論證方法

文章目錄 **一、核心設計原則****二、論證方法****三、常見決策模式****四、驗證方法****五、反模式警示****總結** 在討論軟件功能點應該歸屬哪些模塊時&#xff0c;并沒有放之四海而皆準的固定方法&#xff0c;但可以通過系統化的論證和設計原則來做出合理決策。以下是常見的…

ServBay 1.13.0 更新,新增第三方反向代理/內網穿透

ServBay 作為一款簡化本地開發環境搭建與管理的強大工具&#xff0c;致力于打造一個開箱即用、穩定可靠的本地開發平臺&#xff0c;讓用戶專注于代碼編寫&#xff0c;提升開發效率。 ServBay 1.13.0 正式發布&#xff01;本次更新聚焦于提升本地開發項目的外部可訪問性、增強國…

如何利用樂維網管進行IP管理

IP管理是網絡管理中的關鍵環節&#xff0c;對于保障網絡的正常運行、提升資源利用效率以及保障網絡安全等方面都具有不可忽視的重要性。樂維網管在IP管理方面具有多種實用功能&#xff0c;以下從IP規劃與分配、IP狀態監測、IP沖突處理、IP審計與報表生成四個方面&#xff0c;介…

Go語言學習-->go的跨平臺編譯

Go語言學習–&#xff1e;go的跨平臺編譯 默認我們go build的可執行文件都是當前操作系統可執行的文件&#xff0c;Go語言支持跨平臺編譯——在當前平臺下編譯其他平臺的可執行文件。 eg&#xff1a;在windows界面的代碼&#xff0c;編譯完成后在linux上面運行 實現方式&#…

SpringBoot自動配置原理深度解析

一、引言 SpringBoot的"約定優于配置"理念極大地簡化了Spring應用的開發流程&#xff0c;而其核心魔法就是自動配置(Auto-Configuration)。本文將深入剖析自動配置的實現原理&#xff0c;幫助開發者更好地理解和定制SpringBoot應用。 二、自動配置核心機制 1. Ena…

使用阿里云百煉embeddings+langchain+Milvus實現簡單RAG

使用阿里云百煉embeddingslangchainMilvus實現簡單RAG 注意測試時&#xff0c;替換其中的key、文檔等 import os from langchain_community.embeddings import DashScopeEmbeddings from langchain_community.vectorstores import Milvus from langchain_text_splitters impor…

事件監聽 ——CAD C#二次開發

一、AutoCAD .NET API 事件機制 1. 事件監聽核心 - Database.ModifyObjects 事件 當數據庫中的實體&#xff08;如圖形對象&#xff09;發生修改時觸發&#xff0c;包括&#xff1a; - 幾何屬性變更&#xff08;移動、縮放、旋轉&#xff09;。 - 非幾何屬性變更&#xff08…

動量及在機器人控制中的應用

動量是物理學中的一個基本概念&#xff0c;在機器人學中也有重要應用。以下是詳細解釋&#xff1a; 1. 動量的基本定義 動量&#xff08;Momentum&#xff09;是描述物體運動狀態的物理量&#xff0c;定義為&#xff1a; 線性動量&#xff1a;$ p mv $ $ m $ 為質量&#xf…

LeetCode 2434.使用機器人打印字典序最小的字符串:貪心(棧)——清晰題解

【LetMeFly】2434.使用機器人打印字典序最小的字符串&#xff1a;貪心(棧)——清晰題解 力扣題目鏈接&#xff1a;https://leetcode.cn/problems/using-a-robot-to-print-the-lexicographically-smallest-string/ 給你一個字符串 s 和一個機器人&#xff0c;機器人當前有一個…

影樓精修-AI衣服祛褶皺算法解析

注&#xff1a;為避免侵權&#xff0c;本文所用圖像均為AIGC生成或無版權網站提供&#xff1b; 衣服祛褶皺功能&#xff0c;目前在像素蛋糕、美圖云修、百度網盤AI修圖、阿里云都有相關的功能支持&#xff0c;它的價值就是將不平整的衣服圖像&#xff0c;變得整齊平整&#xf…

Celery 核心概念詳解及示例

Celery 核心概念詳解及示例 Celery 是一個簡單、靈活且可靠的分布式系統&#xff0c;用于處理大量消息&#xff0c;提供對任務隊列的操作&#xff0c;并支持任務的調度和異步執行。它常用于深度優化 Web 應用的性能和響應速度&#xff0c;通過將耗時的操作移到后臺異步執行&am…