当前位置: 首页 > news >正文

Elasticsearch搜索出现NAN异常

原因分析

  • Elasticsearch默认的打分,一般是不会出现异常的
  • 之所以会出现NAN异常,往往是因为我们重新计算了打分,使用了function_score
  • 核心原因是在function_score中,出现了计算异常,比如 0/0,比如log1p(x),x为负数等

真实案例分析

测试索引

PUT tx
POST tx/_mapping
{"properties" : {"age" : {"type" : "long"},"time" : {"type" : "date","format" : "yyyy-MM-dd"},"title" : {"type" : "text","analyzer" : "ik_smart"}}
}
POST tx/_doc/19
{"title":"中古","time" : "1969-10-12","age":12
}

搜索query示例

POST /tx/_search
{"query": {"function_score": {"query": {"match_all": {}},"field_value_factor": {"field": "time","modifier": "log1p"}}}
}
- 其实modifier.log1p和如下搜索是完全一样的
POST /tx/_search
{"query": {"function_score": {"query": {"match_all": {}},"script_score": {"script": "_score * Math.log1p(1+doc['time'].value.toInstant().toEpochMilli())"}}}
}

搜索异常返回值

{"error" : {"root_cause" : [{"type" : "exception","reason" : "function score query returned an invalid score: NaN for doc: 0"}],"type" : "search_phase_execution_exception","reason" : "all shards failed","phase" : "query","grouped" : true,"failed_shards" : [{"shard" : 0,"index" : "tx","node" : "aPOBCVYkRA-a0R9FR4eDzQ","reason" : {"type" : "exception","reason" : "function score query returned an invalid score: NaN for doc: 0"}}]},"status" : 500
}

搜索异常原因分析

  • 搜索使用了function_score重新打分,并且使用了log1p函数
  • 但是由于数据中的时间是"1969-10-12",但是es计算时间是从1970年计算开始,这个值换算成毫秒就是负数,导致log1p异常
  • 所以最终得分异常,出现是NAN
http://www.lryc.cn/news/114943.html

相关文章:

  • (杭电多校)2023“钉耙编程”中国大学生算法设计超级联赛(6)
  • 【JavaScript 】浏览器事件处理
  • (力扣)用两个队列实现栈---C语言
  • 使用 RediSearch 在 Redis 中进行全文检索
  • [Microsoft][ODBC 驱动程序管理器] 未发现数据源名称并且未指定默认驱动程序
  • springboot生成表结构和表数据sql
  • 代码随想录—力扣算法题:209长度最小的子数组.Java版(示例代码与导图详解)
  • 81 | Python可视化篇 —— Seaborn数据可视化
  • 解决Error running XXXApplicationCommand line is too long.报错
  • 【Linux】—— 进程等待 waitwaitpid
  • el-tree 懒加载数据,增删改时局部刷新实现
  • opencv基础44- Canny边缘检测详解-cv.Canny()
  • neo4j查询语言Cypher详解(三)--函数
  • kafka权威指南(阅读摘录)
  • 【爬虫实践】使用Python从网站抓取数据
  • win10 2022unity设置中文
  • python表白代码大全可复制,python表白代码大全简单
  • wordpress 打开缓慢处理
  • Adobe ColdFusion 反序列化漏洞复现(CVE-2023-29300)
  • 林【2018】
  • ffmpeg+nginx实现rtsp协议摄像头web端播放
  • 【周赛第69期】满分题解 软件工程选择题 枚举 dfs
  • P2015 二叉苹果树
  • Linux 内核音频数据传递主要流程
  • torch.device函数
  • 火车头采集器AI伪原创【php源码】
  • Python中常见的6种数据类型
  • 消息队列项目(2)
  • 解决MAC M1处理器运行Android protoc时出现的错误
  • C#使用SnsSharp实现鼠标键盘钩子,实现全局按键响应