Crates.io | tantivy |
lib.rs | tantivy |
version | 0.22.0 |
source | src |
created_at | 2016-08-11 07:56:39.807355 |
updated_at | 2024-04-12 04:49:17.060022 |
description | Search engine library |
homepage | https://github.com/quickwit-oss/tantivy |
repository | https://github.com/quickwit-oss/tantivy |
max_upload_size | |
id | 5951 |
size | 4,183,036 |
If you are looking for an alternative to Elasticsearch or Apache Solr, check out Quickwit, our distributed search engine built on top of Tantivy.
Tantivy is closer to Apache Lucene than to Elasticsearch or Apache Solr in the sense it is not an off-the-shelf search engine server, but rather a crate that can be used to build such a search engine.
Tantivy is, in fact, strongly inspired by Lucene's design.
The following benchmark breakdowns performance for different types of queries/collections.
Your mileage WILL vary depending on the nature of queries and their load.
Details about the benchmark can be found at this repository.
(michael AND jackson) OR "king of pop"
)"michael jackson"
)&[u8]
fast fieldsDistributed search is out of the scope of Tantivy, but if you are looking for this feature, check out Quickwit.
Tantivy works on stable Rust and supports Linux, macOS, and Windows.
tantivy-cli
is an actual command-line interface that makes it easy for you to create a search engine,
index documents, and search via the CLI or a small server with a REST API.
It walks you through getting a Wikipedia search engine up and running in a few minutes.There are many ways to support this project.
We use the GitHub Pull Request workflow: reference a GitHub ticket and/or include a comprehensive commit message when opening a PR. Feel free to update CHANGELOG.md with your contribution.
When implementing a tokenizer for tantivy depend on the tantivy-tokenizer-api
crate.
Tantivy compiles on stable Rust. To check out and run tests, you can simply run:
git clone https://github.com/quickwit-oss/tantivy.git
cd tantivy
cargo test
You can also find other bindings on GitHub but they may be less maintained.
commit
is called on an IndexWriter
. Existing IndexReader
s will also need to be reloaded in order to reflect the changes. Finally, changes are only visible to newly acquired Searcher
.