Milvus 是什么
Milvus 是一款开源的 Embeddings 相似度搜索引擎,支持针对 TB 级 Embeddings 的增删改和近实时搜索,具有高度灵活、稳定可靠以及高速搜索等特点。Milvus 集成了 Faiss、NMSLIB、Annoy 等广泛应用的向量索引库,提供了一整套简单直观的 API,让你可以针对不同场景选择不同的索引类型。此外,Milvus 还可以对标量数据进行过滤,进一步提高了召回率,增强了搜索的灵活性。
Milvus 服务器为主从式架构 (Client-server model)。
在服务端,Milvus 由 Milvus Core 和 Meta Store 两部分组成:
- Milvus Core 存储与管理 Embeddings 和标量数据。
- Meta Store 存储与管理 SQLite 和 MySQL 中的元数据,分别用于测试和生产。
- 在客户端,Milvus 还提供了基于 Python、Java、Go、C++ 的 SDK 和 RESTful API。
Milvus 在 Apache 2 License 协议下发布,于 2019 年 10 月正式开源,是 LF AI 基金会的孵化项目。Milvus 的源代码被托管于 Github。
目前,Milvus 的服务器在单节点上运行。对于有更大数据规模或者高并发需求的用户,可以使用目前尚在开发阶段的集群分片中间件 Mishards 进行部署。
整体架构
应用场景
Milvus 在全球范围内已被数百家组织和机构所采用,广泛应用于以下场景:
- 图像、视频、音频等音视频搜索领域
- 文本搜索、推荐和交互式问答系统等文本搜索领域
- 新药搜索、基因筛选等生物医药领域
详见 应用场景。
主要特性
特征 | 说明 |
---|---|
异构计算 |
|
支持主流的索引库、距离计算方式和向量索引工具 |
|
近实时搜索 | 插入 Milvus 的数据默认在 1 秒后即可被搜索到。 |
标量字段过滤 (即将上线) |
|
加入开发者社区
如果你想为 Milvus 项目贡献代码,请参考我们的代码贡献指南:Contribute to Milvus。
如果你对 Milvus 有任何与功能、SDK 等相关的问题,欢迎加入 Slack 参与讨论。