Go to file
starlord bbc2c90741 format code
Former-commit-id: 1e15f2112b93a17958c2e663fafc79cf39dd3148
2019-10-21 19:30:54 +08:00
.github/ISSUE_TEMPLATE Update documentation-request.md 2019-09-25 18:09:20 +08:00
ci Merge remote-tracking branch 'main/0.5.0' into 0.5.0 2019-10-20 09:56:47 +08:00
core format code 2019-10-21 19:30:54 +08:00
docker update libboost in build environment Dockerfile 2019-10-17 15:06:30 +08:00
tests update java-tests and classified python-tests by opensource and internal case #50 2019-10-19 19:34:46 +08:00
.clang-format format code by clang-tidy 2019-09-28 12:36:14 +08:00
.clang-tidy format code by clang-tidy 2019-09-28 15:00:26 +08:00
.clang-tidy-ignore rename some compile virables 2019-10-15 17:06:05 +08:00
.gitignore re-organize project 2019-10-14 09:51:48 +08:00
CHANGELOG.md #59 Topk result is incorrect for small dataset 2019-10-21 16:46:33 +08:00
CODE_OF_CONDUCT.md Update Documents 2019-10-15 18:43:51 +08:00
CONTRIBUTING.md update README and CONTRIBUTING 2019-10-16 16:17:04 +08:00
LICENSE Initial commit 2019-09-16 14:43:44 +08:00
NOTICE.md Update Documents 2019-10-15 18:43:51 +08:00
README.md Update README.md 2019-10-16 16:48:43 +08:00

Milvuslogo

LICENSE Language

Welcome to Milvus

Firstly, welcome, and thanks for your interest in Milvus! No matter who you are, what you do, we greatly appreciate your contribution to help us reinvent data science with Milvus.

What is Milvus

Milvus is an open source vector search engine that supports similarity search of large-scale vectors. Built on optimized indexing algorithm, it is compatible with major AI/ML models.

Milvus provides stable Python, C++ and Java APIs.

Keep up-to-date with newest releases and latest updates by reading Milvus release notes.

  • GPU-accelerated search engine

    Milvus is designed for the largest scale of vector index. CPU/GPU heterogeneous computing architecture allows you to process data at a speed 1000 times faster.

  • Intelligent index

    With a "Decide Your Own Algorithm" approach, you can embed machine learning and advanced algorithms into Milvus without the headache of complex data engineering or migrating data between disparate systems. Milvus is built on optimized indexing algorithm based on quantization indexing, tree-based and graph indexing methods.

  • Strong scalability

    The data is stored and computed on a distributed architecture. This lets you scale data sizes up and down without redesigning the system.

Architecture

Milvus_arch

Get started

Install using docker

Use Docker to install Milvus is a breeze. See the Milvus install guide for details.

Build from source

Software requirements

  • Ubuntu 18.04 or higher
  • CMake 3.14 or higher
  • CUDA 10.0 or higher
  • NVIDIA driver 418 or higher

Compilation

Step 1 Install dependencies
$ cd [Milvus sourcecode path]/core
./ubuntu_build_deps.sh
Step 2 Build
$ cd [Milvus sourcecode path]/core
$ ./build.sh -t Debug
or 
$ ./build.sh -t Release

When the build is completed, all the stuff that you need in order to run Milvus will be installed under [Milvus root path]/core/milvus.

Launch Milvus server

$ cd [Milvus root path]/core/milvus

Add lib/ directory to LD_LIBRARY_PATH

$ export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/path/to/milvus/lib

Then start Milvus server:

$ cd scripts
$ ./start_server.sh

To stop Milvus server, run:

$ ./stop_server.sh

To edit Milvus settings in conf/server_config.yaml and conf/log_config.conf, please read Milvus Configuration.

Try your first Milvus program

Run Python example code

Make sure Python 3.4 or higher is already installed and in use.

Install Milvus Python SDK.

# Install Milvus Python SDK
$ pip install pymilvus==0.2.0

Create a new file example.py, and add Python example code to it.

Run the example code.

# Run Milvus Python example
$ python3 example.py

Run C++ example code

 # Run Milvus C++ example
 $ cd [Milvus root path]/core/milvus/bin
 $ ./sdk_simple

Run Java example code

Make sure Java 8 or higher is already installed.

Refer to this link for the example code.

Contribution guidelines

Contributions are welcomed and greatly appreciated. If you want to contribute to Milvus, please read our contribution guidelines. This project adheres to the code of conduct of Milvus. By participating, you are expected to uphold this code.

We use GitHub issues to track issues and bugs. For general questions and public discussions, please join our community.

Join the Milvus community

To connect with other users and contributors, welcome to join our slack channel.

Milvus Roadmap

Please read our roadmap to learn about upcoming features.

Resources

Milvus official website

Milvus docs

Milvus bootcamp

Milvus blog

Milvus CSDN

Milvus roadmap

License

Apache 2.0 license