RediSearch - Redis Powered Search Engine
RediSearch is a source available Full-Text and Secondary Index engine over Redis, developed by Redis Labs.
!!! note “Quick Links:” * Source Code at GitHub. * Latest Release * Docker Image: redislabs/redisearch * Quick Start Guide * Mailing list / Forum
!!! tip “Supported Platforms” RediSearch is developed and tested on Linux and Mac OS, on x86_64 CPUs.
i386 CPUs should work fine for small data-sets, but are not tested and not recommended. Atom CPUs are not supported currently.
Overview
Redisearch implements a search engine on top of Redis, but unlike other Redis search libraries, it does not use internal data structures like sorted sets.
This also enables more advanced features, like exact phrase matching and numeric filtering for text queries, that are not possible or efficient with traditional Redis search approaches.
Client Libraries
Official and community client libraries in Python, Java, JavaScript, Ruby, Go, C#, and PHP.
See the Clients page for the full list.
Cluster Support and Commercial Version
RediSearch has a distributed cluster version that can scale to billions of documents and hundreds of servers. However, it is only available as part of Redis Labs Enterprise. We also offer official commercial support for RediSearch. See the Redis Labs Website for more info and contact information.
Primary Features
- Full-Text indexing of multiple fields in documents.
- Incremental indexing without performance loss.
- Document ranking (provided manually by the user at index time).
- Complex boolean queries with AND, OR, NOT operators between sub-queries.
- Optional query clauses.
- Prefix based searches.
- Field weights.
- Auto-complete suggestions (with fuzzy prefix suggestions).
- Exact Phrase Search, Slop based search.
- Stemming based query expansion in many languages (using Snowball).
- Support for custom functions for query expansion and scoring (see Extensions).
- Limiting searches to specific document fields.
- Numeric filters and ranges.
- Geo filtering using Redis’ own Geo-commands.
- Unicode support (UTF-8 input required).
- Retrieve full document content or just ids
- Document deletion and updating with index garbage collection.
- Partial and conditional document updates.
References
Videos
Blog posts
- Mastering RediSearch / Part I
- Mastering RediSearch / Part II
- Mastering RediSearch / Part III
- Search Benchmarking: RediSearch vs. Elasticsearch
Mailing List / Forum
Got questions? Feel free to ask at the RediSearch mailing list.
License
Redis Source Available License Agreement - see LICENSE