Skip to content

milvus-2.5.4

Latest
Compare
Choose a tag to compare
@yanliang567 yanliang567 released this 24 Jan 02:30
· 234 commits to master since this release
6cdabd9

v2.5.4

Release date: January 23, 2025

Milvus version Python SDK version Node.js SDK version Java SDK version
2.5.4 2.5.4 2.5.4 2.5.4

We’re excited to announce the release of Milvus 2.5.4, which introduces key performance optimizations and new features such as PartitionKey isolation, Sparse Index with DAAT MaxScore, and enhanced locking mechanisms. A standout highlight of this release is its support for 10,000 collections and 1 million partitions, marking a major milestone for multi-tenant use cases. This version also addresses multiple bugs that improve overall stability and reliability, two of the critical bugs may cause data loss. We encourage you to upgrade or try out this latest release, and we look forward to your feedback in helping us continually refine Milvus!

Features

  • Supports PartitionKey isolation to improve performance with multiple partition keys (#39245). For more information, refer to Use Partition Key.
  • Sparse Index now supports DAAT MaxScore knowhere/#1015. For more information, refer to Sparse Vector.
  • Adds support for is_null in expression (#38931)
  • Root privileges can be customized (#39324)

Improvements

  • Support 10K collections and 1million partitions in one cluster (#37630)
  • Cached segments’ delta information to accelerate the Query Coordinator (#39349)
  • Read metadata concurrently at the collection level to speed up failure recovery (#38900)
  • Refined lock granularity in QueryNode (#39282), (#38907)
  • Unified style by using CStatus to handle NewCollection CGO calls (#39303)
  • Skipped generating the partition limiter if no partition is set (#38911)
  • Added more RESTful API support (#38875) (#39425)
  • Removed unnecessary Bloom Filters in QueryNode and DataNode to reduce memory usage (#38913)
  • Speeded up data loading by accelerating task generation, scheduling, and execution in QueryCoord (#38905)
  • Reduced locking in DataCoord to speed up load and insert operations (#38904)
  • Added primary field names in SearchResult and QueryResults (#39222)
  • Used both binlog size and index size as the disk quota throttling standard (#38844)
  • Optimized memory usage for full-text search knowhere/#1011
  • Added version control for scalar indexes (#39236)
  • Improved the speed of fetching collection information from RootCoord by avoiding unnecessary copies (#38902)

Critial Bug fixs

  • Fixed search failures for primary keys with indexes (#39390)
  • Fixed potential data loss issue caused by restarting MixCoord and flushing concurrently (#39422)
  • Fixed a delete failure triggered by improper concurrency between stats tasks and L0 compaction after MixCoord restarts (#39460)
  • Fixed scalar inverted index incompatibility when upgrading from 2.4 to 2.5 (#39272)

Bug fixes

  • Fixed slow query issues caused by coarse lock granularity during multi-column loading (#39255)
  • Fixed an issue where using aliases could cause an iterator to traverse the wrong database (#39248)
  • Fixed a resource group update failure when altering the database (#39356)
  • Fixed a sporadic issue where the tantivy index could not delete index files during release (#39434)
  • Fixed slow indexing caused by having too many threads (#39341)
  • Fixed an issue preventing disk quota checks from being skipped during bulk import (#39319)
  • Resolved freeze issues caused by too many message queue consumers by limiting concurrency (#38915)
  • Fixed query timeouts caused by MixCoord restarts during large-scale compactions (#38926)
  • Fixed channel imbalance issues caused by node downtime (#39200)
  • Fixed an issue that could cause channel balance to become stuck. (#39160)
  • Fixed an issue where RBAC custom group privilege level checks became ineffective (#39224)
  • Fixed a failure to retrieve the number of rows in empty indexes (#39210)
  • Fixed incorrect memory estimation for small segments (#38909)