31_Spring AI 干货笔记之嵌入模型 Amazon Bedrock

一、Amazon Bedrock

根据 Bedrock 的建议,Spring AI 已过渡到使用 Amazon Bedrock 的 Converse API 来实现 Spring AI 中的所有聊天对话功能。Bedrock Converse API 具有以下主要优势:

  • 统一接口: 编写一次代码,即可用于任何受支持的 Amazon Bedrock 模型

  • 模型灵活性: 无需更改代码即可在不同对话模型之间无缝切换

  • 扩展功能: 通过专用结构支持特定于模型的参数

  • 工具支持: 原生集成函数调用和工具使用能力

  • 多模态能力: 内置支持视觉和其他多模态功能

  • 面向未来: 符合 Amazon Bedrock 推荐的最佳实践

Converse API 不支持嵌入操作,因此这些操作将保留在当前 API 中,并且现有 InvokeModel API 中的嵌入模型功能将保持不变。

Amazon Bedrock 是一项托管服务,它通过统一的 API 提供来自多个 AI 提供商的基础模型。

Spring AI 通过实现 Spring EmbeddingModel 接口,支持可通过 Amazon Bedrock 使用的 嵌入 AI 模型

此外,Spring AI 为所有客户端提供 Spring 自动配置和 Boot Starter,使得为 Bedrock 模型进行引导和配置变得简单。

二、开始使用

开始使用有几个步骤:

  • 将适用于 Bedrock 的 Spring Boot starter 添加到您的项目中。

  • 获取 AWS 凭证:如果您还没有 AWS 账户和配置好的 AWS CLI,此视频指南 可以帮助您配置:在 4 分钟内完成 AWS CLI 和 SDK 设置!。您应该能够获取您的访问密钥和安全密钥。

  • 启用要使用的模型:转到 Amazon Bedrock,从左侧的 模型访问 菜单中,配置对您将使用的模型的访问权限。

2.1 项目依赖项

然后,将 Spring Boot Starter 依赖项添加到项目的 Maven pom.xml 构建文件中:

xml 复制代码
<dependency>
    <artifactId>spring-ai-starter-model-bedrock</artifactId>
    <groupId>org.springframework.ai</groupId>
</dependency>

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

groovy 复制代码
dependencies {
    implementation 'org.springframework.ai:spring-ai-starter-model-bedrock'
}

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

2.2 连接到 AWS Bedrock

使用 BedrockAwsConnectionProperties 来配置 AWS 凭证和区域:

yaml 复制代码
spring.ai.bedrock.aws.region=us-east-1

spring.ai.bedrock.aws.access-key=YOUR_ACCESS_KEY
spring.ai.bedrock.aws.secret-key=YOUR_SECRET_KEY

spring.ai.bedrock.aws.timeout=10m

region 属性是必需的。

AWS 凭证按以下顺序解析:

  • Spring-AI Bedrock 的 spring.ai.bedrock.aws.access-key 和 spring.ai.bedrock.aws.secret-key 属性。

  • Java 系统属性 - aws.accessKeyId 和 aws.secretAccessKey。

  • 环境变量 - AWS_ACCESS_KEY_ID 和 AWS_SECRET_ACCESS_KEY。

  • 来自系统属性或环境变量的 Web 身份令牌凭证。

  • 所有 AWS SDK 和 AWS CLI 共享的默认位置(~/.aws/credentials)的凭证配置文件。

  • 如果设置了 AWS_CONTAINER_CREDENTIALS_RELATIVE_URI 环境变量并且安全管理器有权访问该变量,则通过 Amazon EC2 容器服务传递的凭证。

  • 通过 Amazon EC2 元数据服务传递的实例配置文件凭证或设置 AWS_ACCESS_KEY_ID 和 AWS_SECRET_ACCESS_KEY 环境变量。

AWS 区域按以下顺序解析:

  • Spring-AI Bedrock 的 spring.ai.bedrock.aws.region 属性。

  • Java 系统属性 - aws.region。

  • 环境变量 - AWS_REGION。

  • 所有 AWS SDK 和 AWS CLI 共享的默认位置(~/.aws/credentials)的凭证配置文件。

  • 通过 Amazon EC2 元数据服务传递的实例配置文件区域。

除了标准的 Spring-AI Bedrock 凭证和区域属性配置外,Spring-AI 还支持自定义的 AwsCredentialsProvider 和 AwsRegionProvider bean。

例如,同时使用 Spring-AI 和 Spring Cloud for Amazon Web Services。Spring-AI 与 Spring Cloud for Amazon Web Services 的凭证配置兼容。

2.3 启用选定的 Bedrock 模型

默认情况下,所有模型都是禁用的。您必须使用 spring.ai.bedrock..embedding.enabled=true 属性显式启用所选的 Bedrock 模型。

以下是支持的 值:

例如,要启用 Bedrock Cohere 嵌入模型,您需要设置 spring.ai.bedrock.cohere.embedding.enabled=true。

接下来,您可以使用 spring.ai.bedrock..embedding.* 属性来配置每个模型,如下所述。

更多信息,请参阅下面每个受支持模型的文档。

  • Spring AI Bedrock Cohere 嵌入:spring.ai.bedrock.cohere.embedding.enabled=true

  • Spring AI Bedrock Titan 嵌入:spring.ai.bedrock.titan.embedding.enabled=true

相关推荐
前进的李工13 小时前
LangChain使用之Model IO(提示词模版之ChatPromptTemplate)
java·前端·人工智能·python·langchain·大模型
AIArchivist13 小时前
深度解析|超级AI医院:不止是概念,更是医疗未来的确定性方向
人工智能·健康医疗
华农DrLai13 小时前
什么是角色扮演Prompt?为什么给AI设定身份能提升表现?
人工智能·深度学习·ai·prompt·bert·transformer
大傻^14 小时前
SpringAI2.0 向量存储生态:Redis、Amazon S3 与 Bedrock Knowledge Base 集成
数据库·人工智能·向量存储·springai
咋个办呢14 小时前
AI智能体自学打卡:一份非常全的 Markdown Prompt 模板(可做减法)
人工智能·ai·prompt·智能体
彷徨的蜗牛14 小时前
智能AI自动化协同发文系统架构设计:从理论到实践的完整指南
人工智能·系统架构·自动化
许国栋_14 小时前
B2B企业如何建设价值管理办公室(VMO)?实践与落地解析
人工智能·安全·云计算·产品经理
一RTOS一14 小时前
从PLC到机器人:实时操作系统如何决定能力上限
人工智能·机器人·鸿道操作系统·鸿道实时操作系统·国产嵌入式操作系统选型·鸿道机器人操作系统
大傻^14 小时前
Spring AI 2.0 企业级 RAG 架构:混合检索、重排序与多模态知识库
人工智能·spring·架构·多模态·rag·混合检索·重排序
yiyu071614 小时前
3分钟搞懂深度学习AI:实操篇:Attention
人工智能·深度学习