Logo

VectorDB: 一个你所需要的Python向量数据库

VectorDB简介

VectorDB是一个专为Python开发者设计的向量数据库,它遵循"你所需要的 - 不多也不少"的理念,提供了一个精简但强大的解决方案。VectorDB建立在DocArray和Jina两个强大框架之上,结合了DocArray的高效向量搜索能力和Jina的可扩展服务能力,为用户提供了一个强大而易用的向量数据库体验。

VectorDB的主要特性

  1. 用户友好的接口: VectorDB设计简洁直观,适合各种水平的用户使用。

  2. 极简设计: 包含所有必要功能,没有多余的复杂性,确保从本地到服务器再到云端部署的无缝过渡。

  3. 完整的CRUD支持: 支持索引、搜索、更新和删除等全套操作。

  4. 数据库即服务: 支持gRPC、HTTP和Websocket协议,让你能够高效地提供数据库服务并进行插入或搜索操作。

  5. 可扩展性: 提供分片和复制等强大的可扩展性特性,通过分片提高服务延迟,通过复制增强可用性和吞吐量。

  6. 云部署: 可以轻松地在Jina AI Cloud上部署你的服务。

  7. 无服务器能力: 可以在云端以无服务器模式部署,确保根据你的需求优化资源利用和数据可用性。

  8. 多种ANN算法: 提供多种近似最近邻(ANN)算法实现,包括:

    • InMemoryExactNNVectorDB: 实现简单的最近邻算法
    • HNSWVectorDB: 利用HNSWLib实现基于HNSW的搜索

快速上手

本地使用VectorDB

  1. 首先定义文档模式:
from docarray import BaseDoc
from docarray.typing import NdArray

class ToyDoc(BaseDoc):
  text: str = ''
  embedding: NdArray[128]
  1. 选择预构建的数据库并应用模式:
from docarray import DocList
import numpy as np
from vectordb import InMemoryExactNNVectorDB

# 指定工作空间路径
db = InMemoryExactNNVectorDB[ToyDoc](workspace='./workspace_path')

# 索引一组带有随机嵌入的文档
doc_list = [ToyDoc(text=f'toy doc {i}', embedding=np.random.rand(128)) for i in range(1000)]
db.index(inputs=DocList[ToyDoc](doc_list))

# 执行搜索查询
query = ToyDoc(text='query', embedding=np.random.rand(128))
results = db.search(inputs=DocList[ToyDoc]([query]), limit=10)

# 打印匹配结果
for m in results[0].matches:
  print(m)

将VectorDB作为服务使用

VectorDB支持作为服务运行,支持gRPC、HTTP和Websocket通信协议。

服务器端:

with db.serve(protocol='grpc', port=12345, replicas=1, shards=1) as service:
   service.block()

客户端:

from vectordb import Client

client = Client[ToyDoc](address='grpc://0.0.0.0:12345')

results = client.search(inputs=DocList[ToyDoc]([query]), limit=10)

高级主题

向量数据库的作用

向量数据库作为嵌入的复杂存储库,捕捉了不同对象之间的语义相似性。这些数据库能够在各种多模态数据类型中进行相似性搜索,开创了信息检索的新时代。通过提供上下文理解和丰富生成结果,向量数据库极大地增强了语言学习模型(LLM)的性能和效用,凸显了它们在数据科学和机器学习应用程序演进中的关键作用。

CRUD支持

VectorDB提供了统一的API支持索引、搜索、更新和删除功能:

  • index: 接受一个DocList进行索引。
  • search: 接受一个查询DocList或单个BaseDoc,返回按相关性排序的匹配结果。
  • delete: 接受要从索引中删除的文档DocList
  • update: 接受要在索引中更新的文档DocList

可扩展性配置

VectorDB提供了两个重要的扩展参数:

  • 分片(Shards): 数据分片数量,可以提高延迟性能。
  • 副本(Replicas): 数据库副本数量,使用RAFT算法在副本之间同步索引,提高服务可用性和搜索吞吐量。

向量搜索配置

VectorDB提供了两种主要的向量数据库类型:

  1. InMemoryExactNNVectorDB: 对嵌入进行穷举搜索,配置选项有限。

  2. HNSWVectorDB: 使用HNSW算法进行近似最近邻搜索,提供多种配置选项用于调整性能和精度。

VectorDB的未来发展

VectorDB团队有着雄心勃勃的发展计划,包括:

  • 支持更多ANN搜索算法
  • 增强过滤能力
  • 提高可定制性
  • 扩展无服务器能力
  • 扩大部署选项

VectorDB项目由Jina AI支持,采用Apache-2.0许可。我们非常欢迎社区贡献,如果你有任何新功能或改进的想法,请随时与我们联系。加入我们的Discord社区,与我们和其他社区成员交流!

VectorDB Logo

通过VectorDB,你可以轻松构建和部署强大的向量搜索应用,无论是本地开发还是云端部署。它简化了向量数据库的使用流程,让开发者能够专注于创造独特的应用体验。无论你是在构建语义搜索、推荐系统,还是其他需要高效向量操作的应用,VectorDB都能成为你得力的工具。

立即开始使用VectorDB,体验简单而强大的Python向量数据库吧!

最新项目

Project Cover
豆包MarsCode
豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。
Project Cover
AI写歌
Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。
Project Cover
商汤小浣熊
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
Project Cover
有言AI
有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。
Project Cover
Kimi
Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。
Project Cover
吐司
探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。
Project Cover
SubCat字幕猫
SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。
Project Cover
AIWritePaper论文写作
AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。
Project Cover
稿定AI
稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。
投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号