news 2026/6/7 12:15:32

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/6/5 10:46:28

Qwen3-8B与vLLM协同推理实战

Qwen3-8B与vLLM协同推理实战 在AI应用加速落地的今天&#xff0c;一个现实问题摆在开发者面前&#xff1a;如何在有限的硬件资源下&#xff0c;让大模型既“跑得动”又“回得快”&#xff1f;尤其是在个人工作站或中小企业服务器上部署高质量语言模型时&#xff0c;显存瓶颈、…

作者头像 李华
网站建设 2026/6/5 8:08:03

网络安全厂商都在亏损裁员,还值得入坑吗?

近年来&#xff0c;互联网行业风声鹤唳&#xff0c;裁员降薪的消息此起彼伏。作为行业的重要支柱&#xff0c;互联网的一举一动自然备受瞩目。但我们需要认识到&#xff0c;这其实是整个社会经济下行的一个缩影&#xff0c;绝不仅仅局限于某个特定领域。 从制造业到服务业&…

作者头像 李华
网站建设 2026/6/6 13:10:46

SGMICRO圣邦微 SGM2006-1.8XN5/TR SOT23-5 线性稳压器(LDO)

特性 低输出噪声:30uVrms(1kHz至100kHz)超低压差电压: 输出150mA时为150mV低负载供电电流:77uA 低功耗:在150mA输出时&#xff0c;工作电流为150μA 高电源抑制比:在1kHz时为73dB 过热保护 输出电流限制预设输出电压(精度士2.7%) 10纳安逻辑控制关断 提供多种输出电压版本 固定…

作者头像 李华
网站建设 2026/6/6 21:24:52

SGMICRO圣邦微 SGM2007-2.5XN5/TR SOT-23-5 线性稳压器(LDO)

特性 低输出噪声:30uVrms(10Hz至100kHz)超低压差电压: 在300mA输出时为300mV低负载时供电电流为77uA在300mA输出时&#xff0c;低功耗运行电流为200μ A 高电源抑制比(在1kHz时为73dB) 热过载保护 输出电流限制-10纳安逻辑控制关断提供多种输出电压版本固定输出电压:1.8V、2.5V…

作者头像 李华
网站建设 2026/6/5 15:08:04

汽车零部件检测的未来:全尺寸、全链条、全生命周期管理

在汽车制造领域&#xff0c;零部件尺寸检测不仅是质量控制的基础环节&#xff0c;更是决定整车装配精度、功能可靠性与市场口碑的核心因素。然而&#xff0c;传统检测方式在面对日益复杂的制造体系和海量数据时&#xff0c;逐渐暴露出效率低下、成本高企以及信息孤岛等问题。这…

作者头像 李华