86_Spring AI 干货笔记之 Chroma 向量存储
一、Chroma本节将引导您设置 Chroma VectorStore 来存储文档嵌入并执行相似性搜索。Chroma 是一个开源的嵌入数据库。它为您提供了存储文档嵌入、内容和元数据的工具,以及搜索这些嵌入(包括元数据过滤)的功能。二、先决条件访问 ChromaDB:与 Chroma Cloud 兼容,或在附录中设置本地 ChromaDB(展示了如何使用 Docker 容器在本地设置数据库)。对于 Chroma Cloud:您需要从 Chroma Cloud 仪表板获取您的 API 密钥、租户名称和数据库名称。对于本地 ChromaDB:除了启动容器外,无需额外配置。一个 EmbeddingModel 实例来计算文档嵌入。有几种选择:(如果需要)一个用于 EmbeddingModel 的 API 密钥,以生成存储在 ChromaVectorStore 中的嵌入。启动时,如果尚未配置,ChromaVectorStore 会创建所需的集合。三、自动配置Spring AI 自动配置、启动器模块的工件名称发生了重大变化。请参阅升级说明以获取更多信息。Spring AI 为 Chroma 向量存储提供了 Spring Boot 自动配置。要启用它,请将以下依赖项添加到项目的 Maven pom.xml 文件中:dependencygroupIdorg.springframework.ai/groupIdartifactIdspring-ai-starter-vector-store-chroma/artifactId/dependency或添加到 Gradle build.gradle 构建文件中:dependencies{implementation'org.springframework.ai:spring-ai-starter-vector-store-chroma'}请参阅 依赖管理 部分,将 Spring AI BOM 添加到您的构建文件中。请参阅 工件仓库 部分,将 Maven Central 和/或快照仓库添加到您的构建文件中。向量存储实现可以为您初始化必要的模式,但您必须通过指定相应构造器中的 initializeSchema 布尔值,或在 application.properties 文件中设置 …​initialize-schema=true 来选择加入。这是一个破坏性变更!在早期版本的 Spring AI 中,此模式初始化是默认发生的。此外,您需要一个配置好的 EmbeddingModel bean。有关更多信息,请参阅 EmbeddingModel 部分。以下是一个所需 bean 的示例:@BeanpublicEmbeddingModelembeddingModel(){// 可以是任何其他 EmbeddingModel 实现。returnnewOpenAiEmbeddingModel(OpenAiApi.builder().apiKey(System.getenv("OPENAI_API_KEY")).build());}要连接到 Chroma,您需要提供实例的访问详细信息。可以通过 Spring Boot 的 application.properties 提供简单的配置:# Chroma 向量存储连接属性spring.ai.vectorstore.chroma.client.host=您的 Chroma 实例主机# 对于 Chroma Cloud:api.trychroma.comspring.ai.vectorstore.chroma.client.port=您的 Chroma 实例端口# 对于 Chroma Cloud:443spring.ai.vectorstore.chroma.client.key-token=您的访问令牌(如果配置)# 对于 Chroma Cloud:使用 API 密钥spring.ai.vectorstore.chroma.client.username=您的用户名(如果配置)spring.ai.vectorstore.chroma.client.password=您的密码(如果配置)# Chroma 向量存储租户和数据库属性(Chroma Cloud 必需)spring.ai.vectorstore.chroma.tenant-name=您的租户名称

相关新闻

【计算机毕业设计案例】基于Hadoop的某篮球队各个球员数据分析系统的设计与实现(程序+文档+讲解+定制)

【计算机毕业设计案例】基于Hadoop的某篮球队各个球员数据分析系统的设计与实现(程序+文档+讲解+定制)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

2026/7/3 14:14:45 阅读更多 →
基于STM32F103驱动QMI8658A输出加速度陀螺仪数据

基于STM32F103驱动QMI8658A输出加速度陀螺仪数据

基于STM32F103驱动QMI8658A输出加速度陀螺仪数据 简介QMI8658A和QMI8658C区别QMI8658A引脚定义QMI8658A寄存器表代码驱动接线代码 现象总结 简介 QMI8658A 是上海矽睿(QST)推出的一款高性能 6 轴惯性测量单元(IMU)芯片&#xff0…

2026/7/4 23:27:44 阅读更多 →
axios和jsdom的碰撞

axios和jsdom的碰撞

node:22.21.1;axios:1.13.4;jsdom:28.0.01、报错代码const axios require(axios) const {JSDOM} require(jsdom);let url https://www.baidu.com JSDOM.fromURL(url).then(dom > console.log(dom))2、不报错代码…

2026/7/5 17:28:35 阅读更多 →

最新新闻

GeoTools 入门实战(一):Shapefile 读取与写入全解析

GeoTools 入门实战(一):Shapefile 读取与写入全解析

目录 一、前言二、环境准备三、GeoTools 核心概念四、读取 Shapefile五、创建新 Shapefile六、完整可运行代码七、常见坑位与注意事项八、工程实践建议九、小结 一、前言 GeoTools 是 Java 生态中最重要的开源 GIS 库,它基于 JTS 提供了完整的空间数据读写能力。…

2026/7/6 0:55:29 阅读更多 →
HiveWE:5个关键功能让魔兽争霸III地图创作变得轻松高效

HiveWE:5个关键功能让魔兽争霸III地图创作变得轻松高效

HiveWE:5个关键功能让魔兽争霸III地图创作变得轻松高效 【免费下载链接】HiveWE A Warcraft III world editor. 项目地址: https://gitcode.com/gh_mirrors/hi/HiveWE 你是否曾想过,制作一张精彩的魔兽争霸III地图可以像绘画一样直观?…

2026/7/6 0:53:28 阅读更多 →
LSTM 时间序列预测:从单步到多步(5步)预测的PyTorch实现与误差分析

LSTM 时间序列预测:从单步到多步(5步)预测的PyTorch实现与误差分析

LSTM时间序列预测:从单步到多步预测的PyTorch实战与误差演化分析当我们需要预测未来多个时间点的数据时,传统的单步预测方法就显得力不从心。本文将深入探讨如何改造标准LSTM模型,实现从t1到t5的多步预测,并系统分析预测步长增加对…

2026/7/6 0:51:28 阅读更多 →
TCN 时间卷积网络 PyTorch 实战:4层残差块构建时序预测模型(附完整代码)

TCN 时间卷积网络 PyTorch 实战:4层残差块构建时序预测模型(附完整代码)

TCN 时间卷积网络 PyTorch 实战:4层残差块构建时序预测模型时序数据预测一直是机器学习领域的重要课题。从股票价格到电力负荷,从气象数据到工业设备状态监测,准确预测未来趋势对决策制定至关重要。传统RNN和LSTM虽然广泛应用,但存…

2026/7/6 0:49:28 阅读更多 →
Selenium + OpenCV 实战:模拟5种人类滑动轨迹,绕过极验3.0行为检测

Selenium + OpenCV 实战:模拟5种人类滑动轨迹,绕过极验3.0行为检测

Selenium OpenCV 实战:5种人类滑动轨迹模拟与极验3.0行为检测绕过在当今的互联网环境中,验证码已成为网站防御自动化工具的第一道防线。其中,极验3.0作为行业领先的行为验证解决方案,通过分析用户操作轨迹来区分人机行为。本文将…

2026/7/6 0:45:27 阅读更多 →
TC78H660FTG与PIC18F87J50的直流电机驱动优化方案

TC78H660FTG与PIC18F87J50的直流电机驱动优化方案

1. 项目背景与核心器件选型在工业自动化和消费电子领域,直流电机驱动系统的效率优化一直是工程师面临的关键挑战。TC78H660FTG作为东芝新一代H桥驱动器,与Microchip的PIC18F87J50微控制器组合,为解决这一问题提供了高性价比方案。TC78H660FTG…

2026/7/6 0:41:26 阅读更多 →

日新闻

H2 与 MySQL 单元测试兼容性:5 个关键 SQL 语句差异与规避方案

H2 与 MySQL 单元测试兼容性:5 个关键 SQL 语句差异与规避方案

H2与MySQL单元测试兼容性:5个关键SQL语句差异与规避方案1. 单元测试中的数据库兼容性挑战在Java开发领域,单元测试是保证代码质量的重要环节。当应用涉及数据库操作时,测试环境的搭建往往成为开发者的痛点。H2数据库因其轻量级、内存模式和快…

2026/7/6 0:01:17 阅读更多 →
Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘

Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘

Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘 【免费下载链接】rbtray A fork of RBTray from http://sourceforge.net/p/rbtray/code/. 项目地址: https://gitcode.com/gh_mirrors/rb/rbtray 你是否厌倦了Windows任务栏上密密麻麻的图标&…

2026/7/6 0:01:17 阅读更多 →
Visual C++ 运行时库一键安装终极指南:告别DLL缺失烦恼

Visual C++ 运行时库一键安装终极指南:告别DLL缺失烦恼

Visual C 运行时库一键安装终极指南:告别DLL缺失烦恼 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾经遇到过这样的情况:下载了…

2026/7/6 0:05:19 阅读更多 →

周新闻

B站视频下载神器BiliTools:5分钟学会轻松保存任何B站内容

B站视频下载神器BiliTools:5分钟学会轻松保存任何B站内容

B站视频下载神器BiliTools:5分钟学会轻松保存任何B站内容 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/BiliTools …

2026/7/5 0:03:34 阅读更多 →
威胁模型全解析:从新手入门到实战应用,助你构建安全产品!

威胁模型全解析:从新手入门到实战应用,助你构建安全产品!

威胁模型的陌生现状在忙碌疲惫的一天里,参与了关于混合后量子密码学的讨论,应付端点攻击找茬的人,还参与留言板讨论后,发现“威胁模型”对多数人仍是陌生概念,且多被当作时髦用语。有趣的相关画作有一幅由 Embyr 创作的…

2026/7/5 0:03:34 阅读更多 →
渗透测试入门指南:从零基础到实战环境搭建

渗透测试入门指南:从零基础到实战环境搭建

1. 从“看热闹”到“入门”:我理解的渗透测试到底是什么?每次看到新闻里说某个大公司的数据被“黑”了,或者某个网站被攻击导致服务瘫痪,你是不是和我一样,心里会冒出两个念头:一是“这黑客真厉害”&#x…

2026/7/5 0:07:38 阅读更多 →

月新闻