README.md 5.5 KB
Newer Older
J
jielinxu 已提交
1
![Milvuslogo](https://github.com/milvus-io/docs/blob/branch-0.5.0/assets/milvus_logo.png)
J
jielinxu 已提交
2

J
jielinxu 已提交
3 4 5
![LICENSE](https://img.shields.io/badge/license-Apache--2.0-brightgreen)
![Language](https://img.shields.io/badge/language-C%2B%2B-blue)

J
JinHai-CN 已提交
6
- [Slack Community](https://join.slack.com/t/milvusio/shared_invite/enQtNzY1OTQ0NDI3NjMzLWNmYmM1NmNjOTQ5MGI5NDhhYmRhMGU5M2NhNzhhMDMzY2MzNDdlYjM5ODQ5MmE3ODFlYzU3YjJkNmVlNDQ2ZTk)
J
jielinxu 已提交
7
- [Twitter](https://twitter.com/milvusio)
J
jielinxu 已提交
8
- [Facebook](https://www.facebook.com/io.milvus.5)
J
jielinxu 已提交
9 10
- [Blog](https://www.milvus.io/blog/)
- [CSDN](https://zilliz.blog.csdn.net/)
J
jielinxu 已提交
11
- [中文官网](https://www.milvus.io/zh-CN/)
J
jielinxu 已提交
12

J
JinHai-CN 已提交
13 14 15

# Welcome to Milvus

J
jielinxu 已提交
16
Firstly, welcome, and thanks for your interest in [Milvus](https://milvus.io)! ​​No matter who you are, what you do, we greatly appreciate your contribution to help us reinvent data science with Milvus.​ :beers:
J
JinHai-CN 已提交
17 18 19

## What is Milvus

J
jielinxu 已提交
20
Milvus is an open source vector search engine which provides state-of-the-art similarity search and analysis for billion-scale feature vectors.
J
JinHai-CN 已提交
21

J
jielinxu 已提交
22
Milvus provides stable Python, Java and C++ APIs.
J
JinHai-CN 已提交
23 24 25 26 27

Keep up-to-date with newest releases and latest updates by reading Milvus [release notes](https://milvus.io/docs/en/Releases/v0.4.0/).

- GPU-accelerated search engine

J
jielinxu 已提交
28
  Milvus uses CPU/GPU heterogeneous computing architecture to process feature vectors, and are orders of magnitudes faster than traditional databases.
J
JinHai-CN 已提交
29

J
jielinxu 已提交
30
- Various indexes
J
JinHai-CN 已提交
31

J
jielinxu 已提交
32
  Milvus supports quantization indexing, tree-based indexing, and graph indexing algorithms. 
J
JinHai-CN 已提交
33

J
jielinxu 已提交
34
- Intelligent scheduling
J
JinHai-CN 已提交
35

J
jielinxu 已提交
36 37 38 39 40
  Milvus optimizes the search computation and index building according to your data size and available resources. 

- Horizontal scalability

  Milvus expands computation and storage by adding nodes during runtime, which allows you to scale the data size without redesigning the system.
J
JinHai-CN 已提交
41 42

## Architecture
J
jielinxu 已提交
43
![Milvus_arch](https://github.com/milvus-io/docs/blob/branch-0.5.0/assets/milvus_arch.jpg)
J
JinHai-CN 已提交
44 45 46

## Get started

J
jielinxu 已提交
47 48 49 50 51 52 53 54 55
### Hardware Requirements

| Component | Recommended configuration           |
| --------- | ----------------------------------- |
| CPU       | Intel CPU Haswell or higher         |
| GPU       | NVIDIA Pascal series or higher      |
| Memory    | 8 GB or more (depends on data size) |
| Storage   | SATA 3.0 SSD or higher              |

J
jielinxu 已提交
56
### Install using docker
J
JinHai-CN 已提交
57 58 59

Use Docker to install Milvus is a breeze. See the [Milvus install guide](https://milvus.io/docs/en/userguide/install_milvus/) for details.

J
jielinxu 已提交
60
### Build from source
J
JinHai-CN 已提交
61

J
jielinxu 已提交
62
#### Software requirements
J
JinHai-CN 已提交
63

J
jielinxu 已提交
64 65 66 67
- Ubuntu 18.04 or higher
- CMake 3.14 or higher
- CUDA 10.0 or higher
- NVIDIA driver 418 or higher
J
JinHai-CN 已提交
68

J
jielinxu 已提交
69
#### Compilation
J
JinHai-CN 已提交
70

J
jielinxu 已提交
71
##### Step 1 Install dependencies
J
JinHai-CN 已提交
72 73

```shell
J
jielinxu 已提交
74 75
$ cd [Milvus sourcecode path]/core
./ubuntu_build_deps.sh
J
JinHai-CN 已提交
76 77
```

J
jielinxu 已提交
78
##### Step 2 Build
J
JinHai-CN 已提交
79 80 81 82 83 84 85 86 87 88

```shell
$ 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`.

J
jielinxu 已提交
89
#### Launch Milvus server
J
JinHai-CN 已提交
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128

```shell
$ 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:

```shell
$ ./stop_server.sh
```

To edit Milvus settings in `conf/server_config.yaml` and `conf/log_config.conf`, please read [Milvus Configuration](https://www.milvus-io/docs/master/reference/milvus_config.md).

### Try your first Milvus program

#### Run Python example code

Make sure [Python 3.4](https://www.python.org/downloads/) or higher is already installed and in use.

Install Milvus Python SDK.

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

J
jielinxu 已提交
129
Create a new file `example.py`, and add [Python example code](https://github.com/milvus-io/pymilvus/blob/master/examples/AdvancedExample.py) to it.
J
JinHai-CN 已提交
130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145

Run the example code.

```python
# Run Milvus Python example
$ python3 example.py
```

#### Run C++ example code

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

J
jielinxu 已提交
146 147 148
#### Run Java example code
Make sure Java 8 or higher is already installed.

J
jielinxu 已提交
149
Refer to [this link](https://github.com/milvus-io/milvus-sdk-java/tree/master/examples) for the example code.
J
jielinxu 已提交
150

J
JinHai-CN 已提交
151 152
## Contribution guidelines

J
jielinxu 已提交
153
Contributions are welcomed and greatly appreciated. If you want to contribute to Milvus, please read our [contribution guidelines](CONTRIBUTING.md). This project adheres to the [code of conduct](CODE_OF_CONDUCT.md) of Milvus. By participating, you are expected to uphold this code.
J
JinHai-CN 已提交
154

J
jielinxu 已提交
155
We use [GitHub issues](https://github.com/milvus-io/milvus/issues/new/choose) to track issues and bugs. For general questions and public discussions, please join our community.
J
JinHai-CN 已提交
156 157 158 159 160 161 162 163 164 165 166 167 168

## Join the Milvus community

To connect with other users and contributors, welcome to join our [slack channel](https://join.slack.com/t/milvusio/shared_invite/enQtNzY1OTQ0NDI3NjMzLWNmYmM1NmNjOTQ5MGI5NDhhYmRhMGU5M2NhNzhhMDMzY2MzNDdlYjM5ODQ5MmE3ODFlYzU3YjJkNmVlNDQ2ZTk). 

## Milvus Roadmap

Please read our [roadmap](https://milvus.io/docs/en/roadmap/) to learn about upcoming features.

## Resources

[Milvus official website](https://www.milvus.io)

J
jielinxu 已提交
169
[Milvus docs](https://www.milvus.io/docs/en/userguide/install_milvus/)
J
JinHai-CN 已提交
170

J
jielinxu 已提交
171 172
[Milvus bootcamp](https://github.com/milvus-io/bootcamp)

J
JinHai-CN 已提交
173 174
[Milvus blog](https://www.milvus.io/blog/)

J
jielinxu 已提交
175
[Milvus CSDN](https://zilliz.blog.csdn.net/)
J
JinHai-CN 已提交
176 177 178 179 180 181

[Milvus roadmap](https://milvus.io/docs/en/roadmap/)


## License

J
jielinxu 已提交
182
[Apache 2.0 license](milvus-io/milvus/LICENSE.md)