2020-03-26 12:24:02 +01:00
< p align = "center" >
2020-04-05 11:02:42 +02:00
< img src = "assets/logo.svg" alt = "MeiliSearch" width = "200" height = "200" / >
2020-03-26 12:24:02 +01:00
< / p >
2020-03-26 12:23:09 +01:00
< h1 align = "center" > MeiliSearch< / h1 >
2019-10-09 16:39:09 +02:00
2020-03-26 12:42:41 +01:00
< h4 align = "center" >
2020-05-27 12:03:23 +02:00
< a href = "https://www.meilisearch.com" > Website< / a > |
2020-12-14 15:38:47 +01:00
< a href = "https://roadmap.meilisearch.com/tabs/1-under-consideration" > Roadmap< / a > |
2020-05-27 12:03:23 +02:00
< a href = "https://blog.meilisearch.com" > Blog< / a > |
< a href = "https://fr.linkedin.com/company/meilisearch" > LinkedIn< / a > |
< a href = "https://twitter.com/meilisearch" > Twitter< / a > |
< a href = "https://docs.meilisearch.com" > Documentation< / a > |
2021-02-02 23:24:56 +01:00
< a href = "https://docs.meilisearch.com/faq/" > FAQ< / a >
2020-03-26 12:42:41 +01:00
< / h4 >
2020-03-26 12:31:58 +01:00
2020-03-26 16:24:03 +01:00
< p align = "center" >
< a href = "https://github.com/meilisearch/MeiliSearch/actions" > < img src = "https://github.com/meilisearch/MeiliSearch/workflows/Cargo%20test/badge.svg" alt = "Build Status" > < / a >
< a href = "https://deps.rs/repo/github/meilisearch/MeiliSearch" > < img src = "https://deps.rs/repo/github/meilisearch/MeiliSearch/status.svg" alt = "Dependency status" > < / a >
2021-04-01 15:52:49 +02:00
< a href = "https://github.com/meilisearch/MeiliSearch/blob/main/LICENSE" > < img src = "https://img.shields.io/badge/license-MIT-informational" alt = "License" > < / a >
2020-03-26 16:24:03 +01:00
< a href = "https://slack.meilisearch.com" > < img src = "https://img.shields.io/badge/slack-MeiliSearch-blue.svg?logo=slack" alt = "Slack" > < / a >
2020-04-20 10:54:08 +02:00
< a href = "https://github.com/meilisearch/MeiliSearch/discussions" alt = "Discussions" > < img src = "https://img.shields.io/badge/github-discussions-red" / > < / a >
2020-07-08 14:33:15 +02:00
< a href = "https://app.bors.tech/repositories/26457" > < img src = "https://bors.tech/images/badge_small.svg" alt = "Bors enabled" > < / a >
2020-03-26 16:24:03 +01:00
< / p >
2019-10-09 16:39:09 +02:00
2020-04-01 16:34:24 +02:00
< p align = "center" > ⚡ Lightning Fast, Ultra Relevant, and Typo-Tolerant Search Engine 🔍< / p >
2019-11-12 16:51:08 +01:00
2020-03-26 12:23:09 +01:00
**MeiliSearch** is a powerful, fast, open-source, easy to use and deploy search engine. Both searching and indexing are highly customizable. Features such as typo-tolerance, filters, and synonyms are provided out-of-the-box.
2020-03-26 11:59:40 +01:00
For more information about features go to [our documentation ](https://docs.meilisearch.com/ ).
2019-10-09 16:39:09 +02:00
2020-03-27 11:28:57 +01:00
< p align = "center" >
2020-11-12 10:05:39 +01:00
< img src = "assets/trumen_quick_loop.gif" alt = "Web interface gif" / >
2020-03-27 11:28:57 +01:00
< / p >
2020-07-02 16:16:53 +02:00
## ✨ Features
2021-06-23 18:30:48 +02:00
* Search-as-you-type experience (answers < 50 milliseconds )
2019-11-26 14:23:56 +01:00
* Full-text search
2021-06-23 18:30:48 +02:00
* Typo tolerant (understands typos and misspelling)
2020-07-02 16:16:53 +02:00
* Faceted search and filters
2021-06-23 18:30:48 +02:00
* Supports hanzi (Chinese characters)
* Supports synonyms
2019-11-26 14:23:56 +01:00
* Easy to install, deploy, and maintain
2020-03-26 11:59:40 +01:00
* Whole documents are returned
2019-11-26 14:23:56 +01:00
* Highly customizable
2020-03-26 11:59:40 +01:00
* RESTful API
2019-10-09 16:39:09 +02:00
2020-07-02 16:16:53 +02:00
## Getting started
2019-11-09 12:59:21 +01:00
### Deploy the Server
2021-01-26 21:14:53 +01:00
#### Homebrew (Mac OS)
2020-05-13 15:41:31 +02:00
2019-12-04 15:36:15 +01:00
```bash
2020-07-02 16:16:53 +02:00
brew update & & brew install meilisearch
meilisearch
2019-12-04 15:36:15 +01:00
```
2020-05-13 15:41:31 +02:00
2020-07-02 16:16:53 +02:00
#### Docker
2019-11-09 12:59:21 +01:00
2019-12-04 15:36:15 +01:00
```bash
2021-03-03 19:15:37 +01:00
docker run -p 7700:7700 -v "$(pwd)/data.ms:/data.ms" getmeili/meilisearch
2019-12-04 15:36:15 +01:00
```
2019-12-02 17:17:16 +01:00
2020-10-22 17:02:58 +02:00
#### Try MeiliSearch in our Sandbox
2021-06-10 14:55:05 +02:00
Create a MeiliSearch instance in [MeiliSearch Sandbox ](https://sandbox.meilisearch.com/ ). This instance is free, and will be active for 48 hours.
2020-10-22 17:02:58 +02:00
2020-07-02 16:16:53 +02:00
#### Run on Digital Ocean
2020-01-08 11:30:33 +01:00
2020-07-02 16:16:53 +02:00
[![DigitalOcean Marketplace ](assets/do-btn-blue.svg )](https://marketplace.digitalocean.com/apps/meilisearch?action=deploy& refcode=7c67bd97e101)
2020-01-08 11:30:33 +01:00
2020-11-17 21:05:17 +01:00
#### Deploy on Platform.sh
< a href = "https://console.platform.sh/projects/create-project?template=https://raw.githubusercontent.com/platformsh/template-builder/master/templates/meilisearch/.platform.template.yaml&utm_content=meilisearch&utm_source=github&utm_medium=button&utm_campaign=deploy_on_platform" >
< img src = "https://platform.sh/images/deploy/lg-blue.svg" alt = "Deploy on Platform.sh" width = "180px" / >
< / a >
2020-07-02 16:16:53 +02:00
#### APT (Debian & Ubuntu)
2019-12-05 14:02:36 +01:00
```bash
echo "deb [trusted=yes] https://apt.fury.io/meilisearch/ /" > /etc/apt/sources.list.d/fury.list
apt update & & apt install meilisearch-http
meilisearch
```
2020-07-02 16:16:53 +02:00
#### Download the binary (Linux & Mac OS)
2019-12-04 15:36:15 +01:00
```bash
2019-12-02 17:17:16 +01:00
curl -L https://install.meilisearch.com | sh
./meilisearch
2019-11-13 15:37:21 +01:00
```
2019-12-04 15:36:15 +01:00
#### Compile and run it from sources
2020-04-26 14:18:20 +02:00
If you have the latest stable Rust toolchain installed on your local system, clone the repository and change it to your working directory.
2019-12-04 15:36:15 +01:00
```bash
git clone https://github.com/meilisearch/MeiliSearch.git
cd MeiliSearch
cargo run --release
```
2019-11-09 12:59:21 +01:00
### Create an Index and Upload Some Documents
2020-03-26 11:59:40 +01:00
Let's create an index! If you need a sample dataset, use [this movie database ](https://www.notion.so/meilisearch/A-movies-dataset-to-test-Meili-1cbf7c9cfa4247249c40edfa22d7ca87#b5ae399b81834705ba5420ac70358a65 ). You can also find it in the `datasets/` directory.
2019-12-02 17:17:16 +01:00
```bash
2019-12-10 16:49:22 +01:00
curl -L 'https://bit.ly/2PAcw9l' -o movies.json
2019-12-02 17:17:16 +01:00
```
2021-08-09 14:56:43 +02:00
Now, you're ready to index some data.
2019-11-09 12:59:21 +01:00
```bash
2019-11-29 18:02:32 +01:00
curl -i -X POST 'http://127.0.0.1:7700/indexes/movies/documents' \
2019-11-09 12:59:21 +01:00
--header 'content-type: application/json' \
2019-12-02 17:17:16 +01:00
--data-binary @movies .json
2019-11-09 12:59:21 +01:00
```
### Search for Documents
2019-12-18 10:09:03 +01:00
#### In command line
2020-05-27 12:03:23 +02:00
The search engine is now aware of your documents and can serve those via an HTTP server.
2020-03-26 13:18:11 +01:00
2020-03-26 11:59:40 +01:00
The [`jq` command-line tool ](https://stedolan.github.io/jq/ ) can greatly help you read the server responses.
2019-11-09 12:59:21 +01:00
```bash
2019-12-02 17:17:16 +01:00
curl 'http://127.0.0.1:7700/indexes/movies/search?q=botman+robin& limit=2' | jq
2019-11-09 12:59:21 +01:00
```
```json
{
"hits": [
{
2019-12-02 17:17:16 +01:00
"id": "415",
"title": "Batman & Robin",
"poster": "https://image.tmdb.org/t/p/w1280/79AYCcxw3kSKbhGpx1LiqaCAbwo.jpg",
2021-06-30 16:58:02 +02:00
"overview": "Along with crime-fighting partner Robin and new recruit Batgirl, Batman battles the dual threat of frosty genius Mr. Freeze and homicidal horticulturalist Poison Ivy. Freeze plans to put Gotham City on ice, while Ivy tries to drive a wedge between the dynamic duo.",
"release_date": 866768400
2019-11-09 12:59:21 +01:00
},
{
2019-12-02 17:17:16 +01:00
"id": "411736",
"title": "Batman: Return of the Caped Crusaders",
"poster": "https://image.tmdb.org/t/p/w1280/GW3IyMW5Xgl0cgCN8wu96IlNpD.jpg",
2021-06-30 16:58:02 +02:00
"overview": "Adam West and Burt Ward returns to their iconic roles of Batman and Robin. Featuring the voices of Adam West, Burt Ward, and Julie Newmar, the film sees the superheroes going up against classic villains like The Joker, The Riddler, The Penguin and Catwoman, both in Gotham City… and in space.",
"release_date": 1475888400
2019-11-09 12:59:21 +01:00
}
],
2021-06-30 16:58:02 +02:00
"nbHits": 8,
"exhaustiveNbHits": false,
"query": "botman robin",
2019-11-09 12:59:21 +01:00
"limit": 2,
2021-06-30 16:58:02 +02:00
"offset": 0,
"processingTimeMs": 2
2019-11-09 12:59:21 +01:00
}
```
2020-03-26 11:59:40 +01:00
#### Use the Web Interface
2019-12-18 10:09:03 +01:00
2021-06-30 16:58:02 +02:00
We also deliver an **out-of-the-box [web interface](https://github.com/meilisearch/mini-dashboard)** in which you can test MeiliSearch interactively.
2019-12-18 10:09:03 +01:00
2020-03-26 13:18:11 +01:00
You can access the web interface in your web browser at the root of the server. The default URL is [http://127.0.0.1:7700 ](http://127.0.0.1:7700 ). All you need to do is open your web browser and enter MeiliSearch’ s address to visit it. This will lead you to a web page with a search bar that will allow you to search in the selected index.
2019-12-18 10:09:03 +01:00
2020-07-02 16:16:53 +02:00
| [See the gif above ](#demo )
2020-03-26 21:56:27 +01:00
2020-07-02 16:16:53 +02:00
## Documentation
2019-12-02 17:17:16 +01:00
2020-05-27 12:03:23 +02:00
Now that your MeiliSearch server is up and running, you can learn more about how to tune your search engine in [the documentation ](https://docs.meilisearch.com ).
2019-12-02 17:17:16 +01:00
2019-11-26 14:23:56 +01:00
## Contributing
2019-10-09 16:39:09 +02:00
2021-03-30 12:21:51 +02:00
Hey! We're glad you're thinking about contributing to MeiliSearch! However, we are currently working on a huge refactor and accepting PRs on this repository wouldn't be productive. We are sorry about this! Be sure we are doing our best so that you can contribute to MeiliSearch again as soon as possible ❤️
2019-11-21 19:15:33 +01:00
2021-08-19 16:24:12 +02:00
## Core engine and tokenizer
The code in this repository is only concerned with managing multiple indexes, handling the update store, and exposing an HTTP API.
Search and indexation are the domain of our core engine, [`milli` ](https://github.com/meilisearch/milli ), while tokenization is handled by [our `tokenizer` library ](https://github.com/meilisearch/tokenizer/ ).
2020-07-02 16:16:53 +02:00
## Telemetry
2019-11-21 19:15:33 +01:00
2020-07-02 16:16:53 +02:00
MeiliSearch collects anonymous data regarding general usage.
2021-02-20 18:49:59 +01:00
This helps us better understand developers' usage of MeiliSearch features.
2021-02-16 22:21:50 +01:00
To see what information we're retrieving, please see the complete list [on the dedicated issue ](https://github.com/meilisearch/MeiliSearch/issues/720 ).
2020-08-28 14:44:53 +02:00
This program is optional, you can disable these analytics by using the `MEILI_NO_ANALYTICS` env variable.
2020-03-26 13:10:44 +01:00
2021-08-09 14:56:43 +02:00
## Feature request
The feature requests are not managed in this repository. Please visit our [dedicated repository ](https://github.com/meilisearch/product ) to see our work about the MeiliSearch product.
If you have a feature request or any feedback about an existing feature, please open [a discussion ](https://github.com/meilisearch/product/discussions ).
2021-08-09 16:38:52 +02:00
Also, feel free to participate in the current discussions, we are looking forward to reading your comments.
2021-08-09 14:56:43 +02:00
2020-07-02 16:16:53 +02:00
## 💌 Contact
2020-03-26 13:10:44 +01:00
2021-08-09 14:56:43 +02:00
Please visit [this page ](https://docs.meilisearch.com/learn/what_is_meilisearch/contact.html#contact-us ).
2020-03-26 13:10:44 +01:00
2020-07-02 16:16:53 +02:00
MeiliSearch is developed by [Meili ](https://www.meilisearch.com ), a young company. To know more about us, you can [read our blog ](https://blog.meilisearch.com ). Any suggestion or feedback is highly appreciated. Thank you for your support!