Google VertexAI Text Embeddings

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

Vertex AI 文本嵌入 API 采用密集向量表示法。与稀疏向量不同,后者倾向于直接将单词映射为数字,而密集向量旨在更好地表达文本的含义。在生成式 AI 中使用密集向量嵌入的优势在于,您不再局限于寻找直接的词汇或句法匹配,而是能够更有效地检索与查询意义相符的段落,即便这些段落使用的语言并不相同。

前提条件(Prerequisites)

  • 安装适用于您操作系统的 gcloud CLI。
  • 通过运行以下命令进行身份验证。将 PROJECT_ID 替换为您的 Google Cloud 项目 ID,将 ACCOUNT 替换为您的 Google Cloud 用户名
gcloud config set project <PROJECT_ID> &&
gcloud auth application-default login <ACCOUNT>

添加存储库和 BOM

Spring AI 工件发布在 Spring MilestoneSnapshot 存储库中。请参阅存储库部分将这些存储库添加到您的构建系统中。

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

自动配置(Auto-configuration)

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'
}

嵌入属性(Embedding Properties)

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

属性 描述 默认值
spring.ai.vertex.ai.embedding.project-id Google 云平台项目ID -
spring.ai.vertex.ai.embedding.location 区域 -
spring.ai.vertex.ai.embedding.apiEndpoint Vertex AI 嵌入API端点 -

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

属性 描述 默认值
spring.ai.vertex.ai.embedding.text.enabled (已移除且不再有效) 启用 Vertex AI 嵌入API模型 true
spring.ai.model.embedding.text 启用 Vertex AI 嵌入API模型 vertexai
spring.ai.vertex.ai.embedding.text.options.model 使用的Vertex文本嵌入模型 text-embedding-004
spring.ai.vertex.ai.embedding.text.options.task-type 指定下游应用类型以帮助模型生成更高质量的嵌入,可选的任务类型 RETRIEVAL_DOCUMENT
spring.ai.vertex.ai.embedding.text.options.title 可选标题(仅当task_type=RETRIEVAL_DOCUMENT时有效) -
spring.ai.vertex.ai.embedding.text.options.dimensions 输出嵌入向量的维度数(支持004及更高版本模型),可用于减小嵌入大小(如存储优化) -
spring.ai.vertex.ai.embedding.text.options.auto-truncate 设为true时自动截断输入文本;设为false时若输入超过模型最大长度将返回错误 true

示例控制器(Sample Controller)

创建一个新的 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使用 EmbeddingClient 的简单示例。

@RestController
public class EmbeddingController {

    private final VertexAiTextEmbeddingModel embeddingModel;

    @Autowired
    public EmbeddingController(VertexAiTextEmbeddingModel embeddingModel) {
        this.embeddingModel = embeddingModel;
    }

    @GetMapping("/v1/embedding")
    public Map<String, Object> embedding(@RequestParam(value = "message", defaultValue = "Tell me a joke") String message) {
        return Map.of("embeddings", embeddingModel.embed(message));
    }

}

手动配置(Manual Configuration)

VertexAiTextEmbeddingModel 实现了 EmbeddingModel , 并使用轻量级 OpenAiApi 客户端连接到 OpenAI 服务。

要启用它,添加 spring-ai-vertex-ai-embedding 依赖到你的项目 Maven pom.xml 文件:

<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'
}

接下来,创建一个 VertexAiTextEmbeddingModel 实例,并使用它来计算两个输入文本之间的相似度:

VertexAiEmbeddingConnectionDetails connectionDetails =
    VertexAiEmbeddingConnectionDetails.builder()
        .projectId(System.getenv(<VERTEX_AI_GEMINI_PROJECT_ID>))
        .location(System.getenv(<VERTEX_AI_GEMINI_LOCATION>))
        .build();

VertexAiTextEmbeddingOptions options = VertexAiTextEmbeddingOptions.builder()
    .model(VertexAiTextEmbeddingOptions.DEFAULT_MODEL_NAME)
    .build();

var embeddingModel = new VertexAiTextEmbeddingModel(this.connectionDetails, this.options);

EmbeddingResponse embeddingResponse = this.embeddingModel
    .embedForResponse(List.of("Hello World", "World is big and salvation is near"));

从 Google 服务账户加载凭证

要以编程方式从服务账户的 json 文件加载 GoogleCredentials,可采用以下方法:

GoogleCredentials credentials = GoogleCredentials.fromStream(<INPUT_STREAM_TO_CREDENTIALS_JSON>)
        .createScoped("https://www.googleapis.com/auth/cloud-platform");
credentials.refreshIfExpired();

VertexAiEmbeddingConnectionDetails connectionDetails =
    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());
作者:Jeebiz  创建时间:2025-08-08 00:49
最后编辑:Jeebiz  更新时间:2025-08-31 23:07