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

J
jielinxu 已提交
3 4
![LICENSE](https://img.shields.io/badge/license-Apache--2.0-brightgreen)
![Language](https://img.shields.io/badge/language-C%2B%2B-blue)
Y
yinghao.zou 已提交
5
[![codebeat badge](https://codebeat.co/badges/e030a4f6-b126-4475-a938-4723d54ec3a7?style=plastic)](https://codebeat.co/projects/github-com-jinhai-cn-milvus-master)
J
jielinxu 已提交
6

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

J
JinHai-CN 已提交
14 15 16

# Welcome to Milvus

J
jielinxu 已提交
17
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 已提交
18 19 20

## What is Milvus

J
jielinxu 已提交
21
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 已提交
22

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

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 已提交
29
  Milvus uses CPU/GPU heterogeneous computing architecture to process feature vectors, and are orders of magnitudes faster than traditional databases.
J
JinHai-CN 已提交
30

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

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

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

J
jielinxu 已提交
37 38 39 40 41
  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 已提交
42 43

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

## Get started

J
jielinxu 已提交
48 49 50 51 52 53 54 55 56
### 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 已提交
57
### Install using docker
J
JinHai-CN 已提交
58 59 60

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 已提交
61
### Build from source
J
JinHai-CN 已提交
62

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

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

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

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

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

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

```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 已提交
90
#### Launch Milvus server
J
JinHai-CN 已提交
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114

```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
```

J
jielinxu 已提交
115
To edit Milvus settings in `conf/server_config.yaml` and `conf/log_config.conf`, please read [Milvus Configuration](https://github.com/milvus-io/docs/blob/master/reference/milvus_config.md).
J
JinHai-CN 已提交
116 117 118 119 120 121 122 123 124 125 126 127 128 129

### 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 已提交
130
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 已提交
131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146

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 已提交
147 148 149
#### Run Java example code
Make sure Java 8 or higher is already installed.

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

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

J
jielinxu 已提交
154
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 已提交
155

J
jielinxu 已提交
156
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 已提交
157 158 159 160 161 162 163 164 165 166 167 168 169

## 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 已提交
170
[Milvus docs](https://www.milvus.io/docs/en/userguide/install_milvus/)
J
JinHai-CN 已提交
171

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

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

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

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


## License

J
jielinxu 已提交
183 184
[Apache 2.0 license](LICENSE)