news 2026/4/9 19:38:19

44_Spring AI 干货笔记之 Google VertexAI 文本嵌入模型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
44_Spring AI 干货笔记之 Google VertexAI 文本嵌入模型

一、Google VertexAI 文本嵌入模型

Vertex AI 支持两种类型的嵌入模型:文本嵌入和多模态嵌入。本文档介绍如何使用 Vertex AI 文本嵌入 API 创建文本嵌入。

Vertex AI 文本嵌入 API 使用稠密向量表示。与直接映射单词到数字的稀疏向量不同,稠密向量旨在更好地表示文本的含义。在生成式 AI 中使用稠密向量嵌入的优点是,您可以更好地搜索与查询含义相符的段落,而不仅仅是搜索直接的单词或语法匹配,即使这些段落使用的语言不同。

二、先决条件

安装适用于您操作系统的 gcloud CLI。

通过运行以下命令进行身份验证。请将 <PROJECT_ID> 替换为您的 Google Cloud 项目 ID,将 替换为您的 Google Cloud 用户名。

gcloud configsetproject<PROJECT_ID>&&gcloud auth application-default login<ACCOUNT>

添加仓库和 BOM

Spring AI 的构件发布在 Maven Central 和 Spring Snapshot 仓库中。请参阅 构件仓库 部分,将这些仓库添加到您的构建系统中。

为便于依赖管理,Spring AI 提供了 BOM(物料清单),以确保在整个项目中使用统一版本的 Spring AI。请参阅 依赖管理 部分,将 Spring AI BOM 添加到您的构建系统中。

三、自动配置

Spring AI 的自动配置和启动器模块的构件名称发生了重大变化。更多信息请参阅升级说明。

Spring AI 为 VertexAI 嵌入模型提供了 Spring Boot 自动配置。要启用它,请在项目的 Maven pom.xml 文件中添加以下依赖:

<dependency><groupId>org.springframework.ai</groupId><artifactId>spring-ai-starter-model-vertex-ai-embedding</artifactId></dependency>

或在您的 Gradle build.gradle 构建文件中添加:

dependencies{implementation'org.springframework.ai:spring-ai-starter-model-vertex-ai-embedding'}

请参阅 依赖管理 部分,将 Spring AI BOM 添加到您的构建文件中。

嵌入属性

前缀 spring.ai.vertex.ai.embedding 用作属性前缀,用于连接到 VertexAI 嵌入 API。

现在通过前缀为 spring.ai.model.embedding 的顶级属性来配置嵌入自动配置的启用和禁用。

  • 启用:spring.ai.model.embedding.text=vertexai(默认已启用)

  • 禁用:spring.ai.model.embedding.text=none(或任何与 vertexai 不匹配的值)

此项更改是为了支持配置多个模型。

前缀 spring.ai.vertex.ai.embedding.text 是用于配置 VertexAI 文本嵌入的嵌入模型实现的属性前缀。

四、示例控制器

创建一个新的 Spring Boot 项目,并将 spring-ai-starter-model-vertex-ai-embedding 添加到您的 pom(或 gradle)依赖中。

在 src/main/resources 目录下添加一个 application.properties 文件,以启用和配置 VertexAi 聊天模型:

spring.ai.vertex.ai.embedding.project-id=<YOUR_PROJECT_ID>spring.ai.vertex.ai.embedding.location=<YOUR_PROJECT_LOCATION>spring.ai.vertex.ai.embedding.text.options.model=text-embedding-004

这将创建一个 VertexAiTextEmbeddingModel 实现,您可以将其注入到您的类中。以下是一个使用嵌入模型生成嵌入的简单 @Controller 类示例。

@RestControllerpublicclassEmbeddingController{privatefinalEmbeddingModelembeddingModel;@AutowiredpublicEmbeddingController(EmbeddingModelembeddingModel){this.embeddingModel=embeddingModel;}@GetMapping("/ai/embedding")publicMapembed(@RequestParam(value="message",defaultValue="Tell me a joke")Stringmessage){EmbeddingResponseembeddingResponse=this.embeddingModel.embedForResponse(List.of(message));returnMap.of("embedding",embeddingResponse);}}

五、手动配置

VertexAiTextEmbeddingModel 实现了 EmbeddingModel 接口。

在项目的 Maven pom.xml 文件中添加 spring-ai-vertex-ai-embedding 依赖:

<dependency><groupId>org.springframework.ai</groupId><artifactId>spring-ai-vertex-ai-embedding</artifactId></dependency>

或在您的 Gradle build.gradle 构建文件中添加:

dependencies{implementation'org.springframework.ai:spring-ai-vertex-ai-embedding'}

请参阅依赖管理部分,将 Spring AI BOM 添加到您的构建文件中。

接下来,创建一个 VertexAiTextEmbeddingModel 并使用它进行文本生成:

VertexAiEmbeddingConnectionDetailsconnectionDetails=VertexAiEmbeddingConnectionDetails.builder().projectId(System.getenv(<VERTEX_AI_GEMINI_PROJECT_ID>)).location(System.getenv(<VERTEX_AI_GEMINI_LOCATION>)).build();VertexAiTextEmbeddingOptionsoptions=VertexAiTextEmbeddingOptions.builder().model(VertexAiTextEmbeddingOptions.DEFAULT_MODEL_NAME).build();varembeddingModel=newVertexAiTextEmbeddingModel(this.connectionDetails,this.options);EmbeddingResponseembeddingResponse=this.embeddingModel.embedForResponse(List.of("Hello World","World is big and salvation is near"));

从 Google 服务账户加载凭据

要以编程方式从服务账户 JSON 文件加载 GoogleCredentials,您可以使用以下代码:

GoogleCredentialscredentials=GoogleCredentials.fromStream(<INPUT_STREAM_TO_CREDENTIALS_JSON>).createScoped("https://www.googleapis.com/auth/cloud-platform");credentials.refreshIfExpired();VertexAiEmbeddingConnectionDetailsconnectionDetails=VertexAiEmbeddingConnectionDetails.builder().projectId(System.getenv(<VERTEX_AI_GEMINI_PROJECT_ID>)).location(System.getenv(<VERTEX_AI_GEMINI_LOCATION>)).apiEndpoint(endpoint).predictionServiceSettings(PredictionServiceSettings.newBuilder().setEndpoint(endpoint).setCredentialsProvider(FixedCredentialsProvider.create(credentials)).build());
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 1:34:00

Wan2.2-T2V-A14B在金融可视化领域的创新应用设想

Wan2.2-T2V-A14B在金融可视化领域的创新应用设想 在投资者每天被海量数据、图表和报告淹没的今天&#xff0c;如何让复杂的金融信息真正“被看见”、“被理解”&#xff0c;已成为金融机构内容传播的核心挑战。传统的PPT式财报解读、静态K线图动画早已无法满足用户对沉浸感与即…

作者头像 李华
网站建设 2026/3/31 0:56:42

Qwen3-8B-AWQ部署与长文本处理实践

Qwen3-8B-AWQ部署与长文本处理实践 在当前大模型应用快速落地的背景下&#xff0c;如何在有限硬件资源下实现高效、稳定的推理服务&#xff0c;成为开发者面临的核心挑战之一。尤其对于中小企业和个人研究者而言&#xff0c;动辄需要多张A100支撑的百亿参数模型显然不现实。而…

作者头像 李华
网站建设 2026/3/25 8:32:30

Jetson AGX Orin+FPGA+GMSL+AI具身智能机器视觉解决方案,支持定制

Jetson AGX OrinFPGAGMSLAI机器视觉解决方案全新Jetson AGX Orin视觉开发套件&#xff0c;实现硬件结构、同步功能、驱动框架三重升级&#xff0c;显著提升边缘AI设备视觉感知模块的开发效率与性能表现&#xff1a;| 硬件结构升级——简洁易用套件采用信迈独有子母板分板架构&a…

作者头像 李华
网站建设 2026/4/3 9:51:39

AI能源效率危机:大模型能耗远超人类大脑,如何实现可持续发展?

引言 当GPT-3单次训练消耗1287MWh电力&#xff0c;相当于1000户中国家庭一年的用电量&#xff0c;当全球大模型年耗电量已达24.97-41.1 TWh&#xff08;约为三峡工程年发电量的40%&#xff09;&#xff0c;AI技术的爆发式增长正遭遇能源效率的严峻拷问。与大模型的巨量能耗形成…

作者头像 李华
网站建设 2026/4/3 19:52:07

鸿蒙应用签名与上架全流程:从开发完成到用户手中

鸿蒙应用签名与上架全流程&#xff1a;从开发完成到用户手中 一、章节概述 ✅ 学习目标 掌握鸿蒙应用签名的核心原理与证书体系熟练完成应用签名与打包操作理解AppGallery Connect上架流程具备应用审核问题的处理能力构建应用发布的标准化流程 &#x1f4a1; 重点内容 签名…

作者头像 李华