首页
/ Manticore Search中KNN搜索与OR操作符组合导致崩溃问题分析

Manticore Search中KNN搜索与OR操作符组合导致崩溃问题分析

2025-05-23 08:10:50作者:庞队千Virginia

问题背景

Manticore Search是一款高性能的开源搜索引擎,近期在6.3.6版本中发现了一个严重问题:当用户尝试将KNN(K-Nearest Neighbors)向量搜索与OR逻辑操作符组合使用时,会导致服务崩溃并产生核心转储。

问题重现

该问题可以通过以下步骤重现:

  1. 创建一个包含向量字段的表
  2. 插入一些测试数据
  3. 执行包含KNN搜索和OR条件的查询

具体表现为执行类似如下的查询语句时会导致服务崩溃:

SELECT id FROM table 
WHERE knn(vector_field, 100, (0.0026,0.7130,...), 2000) 
OR id IN (17288196142531670, 17288196142532330)

技术分析

这个问题的本质在于Manticore Search 6.3.6版本中KNN搜索功能的实现存在缺陷,当与OR逻辑操作符组合时,系统无法正确处理查询条件,导致内存访问越界或其他严重错误,最终引发服务崩溃。

从技术实现角度看,KNN搜索作为向量搜索功能,与传统的文本搜索在查询处理流程上有显著差异。当系统尝试将这两种不同类型的搜索条件通过OR操作符组合时,查询优化器和执行引擎未能正确处理这种混合场景。

解决方案

经过开发团队确认,该问题在开发版本中已经得到修复。新版本中当尝试执行此类查询时,会返回明确的错误信息"filter with empty name",而不是直接崩溃。

对于需要使用混合搜索条件的用户,目前Manticore Search官方建议:

  1. 升级到已修复该问题的开发版本
  2. 避免直接使用OR操作符组合KNN搜索和其他条件
  3. 考虑使用其他方式实现混合搜索需求

未来展望

虽然当前版本中OR与KNN的组合使用会导致问题,但社区已经认识到这种混合搜索场景的实际需求。相关功能改进和更完善的混合搜索支持已被列入开发计划,未来版本有望提供更优雅的解决方案。

对于需要立即使用混合搜索功能的用户,可以考虑通过应用层逻辑或多次查询的方式实现类似效果,虽然这会增加一定的复杂度,但可以避免系统崩溃的风险。

登录后查看全文
热门项目推荐
相关项目推荐