RediSearch 2.10 release notes
New vector data types. Enhanced indexing capabilities. Simplified query syntax. Expanded geospatial search.
Requirements
RediSearch v2.10.7 requires:
- Minimum Redis compatibility version (database): 7.4
- Minimum Redis Enterprise Software version (cluster): 7.6 (TBD)
v2.10.7 (Septermber 2024)
This is a maintenance release for RediSearch 2.10
Update urgency: HIGH
: There is a critical bug that may affect a subset of users. Upgrade!
Bug Fixes
- https://github.com/RediSearch/RediSearch/pull/4941 Adjusting the module configuration to avoid routing overload on the first shard in a clustered database (MOD-7505)
- https://github.com/RediSearch/RediSearch/pull/4950
FT.PROFILE
onAGGREGATE
numeric queries could cause a crash due to reuse of an internal CURSOR in a large range of numeric values (MOD-7454)
v2.10.6 (August 2024):
This is a maintenance release for RediSearch 2.10.
Update urgency: HIGH
- There is a critical bug that may affect a subset of users. Upgrade!
Bug fixes:
- #4916 - Union query, similar to
"is|the"
, starting with 2 storwords could cause a crash (MOD-7495) - #4895 -
FT.AGGREGATE
withVERBATIM
option is not handled by the shards in cluster mode (MOD-7463) - #4922 - Counting twice the field statistics at
#search
section ofINFO
response (MOD-7339)
v2.10 GA (v2.10.5) (July 2024)
This is the General Availability release of RediSearch 2.10
Headlines:
This latest RediSearch introduces memory-efficient vector data types, enhanced indexing capabilities with support for empty and missing fields, simplified query syntax, and expanded geospatial search features.
What's new in 2.10.5
This new major version introduces new BFLOAT16
and FLOAT16
vector data types, reducing memory consumed by vectors while preserving accuracy. This update also includes highly-requested support for indexing empty and missing values and enhances the developer experience for queries with exact matching capabilities. Developers can now match TAG
fields without needing to escape special characters, making the onboarding process and use of the query syntax easier. Lastly, Geospatial search capabilities have been expanded with new INTERSECT
and DISJOINT
operators, and ergonomics have been improved by providing better reporting of the memory consumed by the index and exposing the full-text scoring in an aggregation pipeline.
Features:
-
Enhancing exact matching queries with
TAG
avoiding escaping special meaning characters using the simpler syntax'@tag:{"my-query%term"}'
andNUMERIC
queries:- #4802 - Using double quotes to wrap exact matching query terms such as
@email:{"[email protected]"}
inDIALECT 2
( MOD-7299) - #4676, #4433 - Enhancing query parser to avoid unnecessary escaping (MOD-5756)
- #4527 - Enhancing exact matching queries for
NUMERIC
using single valueFT.SEARCH idx @numeric:[3456]
(MOD-6623) - #4802 - Enabling support for single operators in
NUMERIC
queries such as equivalence==
, difference!=
, greater than>
and>=
and less than<
and<=
as inFT.SEARCH idx '@numeric==3456'
(MOD-6749)
- #4802 - Using double quotes to wrap exact matching query terms such as
-
Adding new keywords to support indexing empty values using
INDEXEMPTY
and missing values usingINDEXMISSING
per field in theSCHEMA
while defining the index withFT.CREATE
- #4663, #4721 - Indexing empty strings values
""
forTAG
andTEXT
fields (MOD-6540, MOD-7200) - #4721 - Updating the query parser to support empty value queries for
TEXT
asFT.SEARCH idx '@text_field:""'
orFT.SEARCH idx '""'
and forTAG
as inFT.SEARCH idx '@tag_field:{""}'
(MOD-7200) - #4720, #4635 - Indexing missing values for all field types introducing the query syntax function
ismissing(@field)
enabling query for missing fields as inFT.SEARCH idx 'ismissing(@text)'
(MOD-6532)
- #4663, #4721 - Indexing empty strings values
-
Enabling new vector data types reducing memory consumed by vectors with the new
BFLOAT16
andFLOAT16
- #4674 - Adding support
BFLOAT16
andFLOAT16
in the vector index definition (MOD-6765, MOD-6776)
- #4674 - Adding support
-
Exposing the full-text score values during the aggregation pipeline using
ADDSCORE
. When calling the scores you can use@__score
in the pipeline as inFT.AGGREGATE idx 'hello' ADDSCORES SORTBY 2 @__score DESC
- #4859 - Expose scores to
FT.AGGREGATE
pipeline (MOD-7190)
- #4859 - Expose scores to
-
#4227 - Adding support for new operators
INTERSECT
andDISJOINT
when querying forGEOSHAPE
polygons (MOD-6178)
Bug fixes (since 2.10.4):
- #4854 - Avoid expansion on stemming from numeric values (MOD-7025)
Improvements (since 2.10.4):
- #4865 - Add coverage for cleaning garbage entries when indexing missing fields (MOD-7415)
- The version inside Redis will be 2.10.5 in semantic versioning. Since the version of a module in Redis is numeric, we could not add a Release Candidate flag.
- Minimal Redis version: 7.4
- If indexing and querying RedisJSON data structures, this version is best combined with RedisJSON 2.8 (v2.8.2 onwards)
- If one or more fields of a hash key expire after a query begins (using FT.SEARCH or FT.AGGREGATE), Redis does not account for these lazily expired fields. As a result, keys with expired fields may still be included in the query results, leading to potentially incorrect or inconsistent results.