记录一次ES异常慢查询(setExplain)

一.问题背景

有个用户在使用ES发现,通过Kibana查询ES数据很快,但是使用java (Spring data tmpleES)去查询时候同样的语句需要12s才能返回数据。

二.排查路径

1.确认现象 Kibana快,ES查询慢

2.定位问题来自JAVA ES查询。确认api用法是否正常

3.查看配置是否正常

执行时候非常慢,看着查询也可以问题。但是等等查询中有个配置参数setExplain(true)?执行计划吗?

三.setExplain(true)

Elasticsearch 的 explain API 允许你深入了解为什么某个文档与查询匹配,或者为什么某个文档的得分是如何计算的。当你在搜索中设置了 setExplain(true) ,Elasticsearch 将返回每个匹配文档的解释,解释了该文档与查询的匹配程度以及得分的计算方式

  • 我们看看效果:
json 复制代码
{
  "_id": "document_id_123",
  "_score": 5.678,
  "_explanation": {
    "value": 5.678,
    "description": "sum of:",
    "details": [
      {
        "value": 2.34,
        "description": "termFreq=2.34",
        "details": []
      },
      {
        "value": 3.34,
        "description": "weight(field:title in document) [default]",
        "details": []
      }
    ]
  }
}

看到了吗 explanation 中详细解释了 "_score": 5.678 的得分细节。

四.会带来什么影响

通常情况下,开启 explain 是为了调试查询或者理解查询结果的产生过程。但是需要注意的是,开启 explain 可能会增加查询的开销,特别是在大型索引中或者查询结果集很大的情况下。因此,建议在开发和调试阶段使用,而不要在生产环境中持续开启。

所以去除这个参数后:

相关推荐
一个做软件开发的牛马7 分钟前
Spring Boot 自动配置原理揭秘:从 @SpringBootApplication 到手写自定义 Starter
java·后端
周杰伦fans20 分钟前
续集:工作空间一切换,我的插件菜单就消失?——MenuBar与Ribbon的自动重载方案
后端·ribbon·c#
可乐ea1 小时前
【Spring Boot + MyBatis|第7篇】JWT 登录认证与拦截器实现
java·spring boot·后端·mybatis·状态模式
西安邮电大学1 小时前
有关栈的经典算法题
java·后端·其他·算法·面试
摇滚侠2 小时前
SpringMVC 入门到实战 配置类替换 XML 配置文件 86-91
xml·java·后端·spring·maven·intellij-idea
我登哥MVP2 小时前
SpringCloud Alibaba 核心组件解析:服务注册与发现(Nacos)
java·spring boot·后端·spring·spring cloud·java-ee·maven
摇滚侠2 小时前
SpringMVC 入门到实战 处理静态资源的过程 64
java·后端·spring·maven·intellij-idea
Liquad Li2 小时前
ABP vNext 标准分层解决方案项目结构完整解析
后端
布朗克1683 小时前
39 Spring Boot Web实战
前端·spring boot·后端·实战
西安邮电大学3 小时前
有关数组的经典算法题
java·后端·其他·算法·面试