A cloud-native vector database, storage for next generation AI applications
 
 
 
 
 
 
Go to file
yanliang567 668dbfbd01
[skip ci]Update log.info instead of log.debug (#8192)
Signed-off-by: yanliang567 <yanliang.qiao@zilliz.com>
2021-09-18 14:13:50 +08:00
.github Remove unused mergify rule (#7926) 2021-09-14 19:47:48 +08:00
build [skip ci] Decrease etcd snapshot-count to 10000 for ci (#8180) 2021-09-18 09:47:50 +08:00
cmd Improve import statements in main.go (#8014) 2021-09-17 11:19:54 +08:00
configs Add knowhere.yaml to support knowhere configuration (#7967) 2021-09-18 10:37:51 +08:00
deployments [skip ci]Update binary installation doc (#8185) 2021-09-18 10:39:51 +08:00
docs Modify the grammatical problem in the document (#8190) 2021-09-18 11:35:51 +08:00
githooks [skip ci]Update approvers (#7063) 2021-08-12 19:36:09 +08:00
internal add collection alias (#7255) 2021-09-18 11:13:51 +08:00
scripts [skip ci] Update cpp codecov script (#8158) 2021-09-17 18:21:52 +08:00
tests [skip ci]Update log.info instead of log.debug (#8192) 2021-09-18 14:13:50 +08:00
tests-deprecating [skip ci] Add comment for reported data (#7972) 2021-09-15 16:37:49 +08:00
tools Rename module (#4988) 2021-04-22 14:45:57 +08:00
.clang-format Refactor cmake and build script and add timed benchmark 2020-10-23 18:01:24 +08:00
.clang-tidy Update registerNode in indexservice 2021-01-20 10:15:43 +08:00
.clang-tidy-ignore Add cpplint and optimize the check of c++ code 2020-11-23 19:57:05 +08:00
.contributors [skip ci]Update all-contributors (#6358) 2021-07-08 12:03:08 +08:00
.devcontainer.json Update main.yaml for Github Action (#6381) 2021-07-09 11:59:09 +08:00
.env Optimize building pytest image workflow (#6928) 2021-08-01 16:14:25 +08:00
.gitignore Prepare for cpp codecoverage (#7900) 2021-09-14 19:05:52 +08:00
.golangci.yml Change Id to ID in go files according to golint check 2020-11-13 15:17:18 +08:00
CHANGELOG.md [skip ci]Update 1.1 changelog (#7609) 2021-09-09 16:24:00 +08:00
CODE_OF_CONDUCT.md Update README 2021-04-21 14:04:22 +08:00
CODE_REVIEW.md [skip ci]Add Code Review Rules for Milvus (#7825) 2021-09-13 20:17:02 +08:00
CONTRIBUTING.md Replace GO with Go in document (#8013) 2021-09-15 23:09:52 +08:00
DEVELOPMENT.md Unify command format in different documents (#8107) 2021-09-17 10:25:50 +08:00
LICENSE Update README 2021-04-21 14:04:22 +08:00
Makefile [skip ci]Prepare for cpp coverage (#8125) 2021-09-17 14:21:50 +08:00
OWNERS Label a pull request when go.mod/go.sum changed (#7919) 2021-09-14 19:41:48 +08:00
OWNERS_ALIASES [skip ci]Add yanliang567 into pr-inspection (#7097) 2021-08-13 17:56:08 +08:00
README.md Change Milvus github star number in readme (#8194) 2021-09-18 11:29:51 +08:00
README_CN.md [skip ci] Update readme (#8131) 2021-09-17 14:29:55 +08:00
codecov.yml [skip ci] Update project code coverage to 78% (#8148) 2021-09-17 17:51:57 +08:00
docker-compose.yml Improve docker-compose config for Pulsar (#7335) 2021-08-29 11:39:57 +08:00
go.mod Upgrade pulsar-client-go to 0.6.0 (#7909) 2021-09-15 18:13:49 +08:00
go.sum Upgrade pulsar-client-go to 0.6.0 (#7909) 2021-09-15 18:13:49 +08:00
milvus20vs1x.md [skip ci]update milvus 2.0 vs 1.x doc (#7832) 2021-09-13 19:32:57 +08:00
ruleguard.rules.go Add DataNode package 2021-01-19 11:37:16 +08:00

README.md

milvus banner

What is Milvus?

Milvus is an open-source vector database built to power embedding similarity search and AI applications. Milvus makes unstructured data search more accessible, and provides a consistent user experience regardless of the deployment environment.

Milvus 2.0 is a cloud-native vector database with storage and computation separated by design. All components in this refactored version of Milvus are stateless to enhance elasticity and flexibility. For more architecture datails, see Milvus Architecture Overview.

Milvus was released under the open-source Apache License 2.0 in October 2019. It is currently a graduate project under LF AI & Data Foundation.

Key features

Millisecond search on trillion vector datasets Average latency measured in milliseconds on trillion vector datasets.
Simplified unstructured data management
  • Rich APIs designed for data science workflows.
  • Consistent user experience across laptop, local cluster, and cloud.
  • Embed real-time search and analytics into virtually any application.
  • Reliable, always on vector database Milvus built-in replication and failover/failback features ensure data and applications can maintain business continuity in the event of a disruption.
    Highly scalable and elastic Component-level scalability makes it possible to scale up and down on demand. Milvus can autoscale at a component level according to the load type, making resource scheduling much more efficient.
    Hybrid search In addition to vectors, Milvus supports data types such as Boolean, integers, floating-point numbers, and more. A collection in Milvus can hold multiple fields for accommodating different data features or properties. Milvus pairs scalar filtering with powerful vector similarity search to offer a modern, flexible platform for analyzing unstructured data.
    Unified Lambda structure Milvus combines stream and batch processing for data storage to balance timeliness and efficiency. Its unified interface makes vector similarity search a breeze.
    Community supported, industry recognized With over 1,000 enterprise users, 7,800+ stars on GitHub, and an active open-source community, youre not alone when you use Milvus. As a graduate project under the LF AI & Data Foundation, Milvus has institutional support.

    Quick start

    Install Milvus

    Build Milvus from source code

    Check the requirements first.

    go: 1.15
    cmake: >=3.16
    gcc: 7.5
    

    Clone Milvus repo and build.

    # Clone github repository.
    $ git clone https://github.com/milvus-io/milvus.git
    
    # Install third-party dependencies.
    $ cd milvus/
    $ ./scripts/install_deps.sh
    
    # Compile Milvus.
    $ make
    

    For the full story, see developer's documentation.

    IMPORTANT The master branch is for the development of Milvus v2.0. On March 9th, 2021, we released Milvus v1.0, the first stable version of Milvus with long-term support. To use Milvus v1.0, switch to branch 1.0.

    Milvus 2.0 vs. 1.x: Cloud-native, distributed architecture, highly scalable, and more

    See Milvus 2.0 vs. 1.x for more information.

    Getting Started

    Demos

    Image search Chatbots Chemical structure search

    Images made searchable. Instantaneously return the most similar images from a massive database.

    Chatbots

    Interactive digital customer service that saves users time and businesses money.

    Blazing fast similarity search, substructure search, or superstructure search for a specified molecule.

    Bootcamps

    Milvus bootcamp are designed to expose users to both the simplicity and depth of the vector database. Discover how to run benchmark tests as well as build similarity search applications spanning chatbots, recommendation systems, reverse image search, molecular search, and much more.

    Contributing

    Contributions to Milvus are welcome from everyone. See Guidelines for Contributing for details on submitting patches and the contribution workflow. See our community repository to learn about our governance and access more community resources.

    All contributors




    Documentation

    For guidance on installation, development, deployment, and administration, check out Milvus Docs.

    SDK

    The implemented SDK and its API documentation are listed below:

    Milvus insight

    Milvus insight provides an intuitive and efficient GUI for Milvus.

    Community

    Join the Milvus community on Slack to share your suggestions, advice, and questions with our engineering team.

    Miluvs Slack Channel

    You can also check out our FAQ page to discover solutions or answers to your issues or questions.

    Subscribe to Milvus mailing lists:

    Follow Milvus on social media:

    Join Us

    Zilliz, the company behind Milvus, is actively hiring algorithm, database, full-stack developers and solution engineers to build the next-generation open-source data fabric.

    Reference

    Reference to cite when you use Milvus in a research paper:

    @inproceedings{2021milvus,
      title={Milvus: A Purpose-Built Vector Data Management System},
      author={Wang, Jianguo and Yi, Xiaomeng and Guo, Rentong and Jin, Hai and Xu, Peng and Li, Shengjun and Wang, Xiangyu and Guo, Xiangzhou and Li, Chengming and Xu, Xiaohai and others},
      booktitle={Proceedings of the 2021 International Conference on Management of Data},
      pages={2614--2627},
      year={2021}
    }
    

    Acknowledgments

    Milvus adopts dependencies from the following:

    • Thanks to FAISS for the excellent search library.
    • Thanks to etcd for providing great open-source key-value store tools.
    • Thanks to Pulsar for its wonderful distributed pub-sub messaging system.
    • Thanks to RocksDB for the powerful storage engines.