记录一次ElasticSearch排错过程Elasticsearch exception [type=search_phase_execution_exception, reason=all shar

JAVA程序从ES查数据时报错:Elasticsearch exception [type=search_phase_execution_exception, reason=all shards failed]

网上有很多解答,但是我想说的是大部分解答都是错误的,由于我本身对ES并不熟悉  参考了别人的解答之后,导致我特么花了一晚上的时间去使用错的方式处理问题。

废话不多说直接写一个解决问题的思路吧:

由于ElasticSearch引用的jar 并没有对ES 的错误进行一个细分导致我们在java程序里拿到的错误都是 Elasticsearch exception [type=search_phase_execution_exception, reason=all shards failed] ,当报错的时候我们第一件事要做的就是原封不动的COPY出查询语句(JAVA里直接调用sourceBuilder.toString() 方法即刻打印查询语句) 然后手动到 ES里执行搜索 ,这时会报出准确的错误,而我的错误就是 「Result window is too large, from + size must be less than or equal to: [10000] but was [10025」,这个问题就很明显了 那么解决方案就是改es索引配置:

PUT index/_settings

{ "index":{ "max_result_window":1000000 }  

设置好后再次执行查询,没有报错了。

你可能感兴趣的:(java,数据库)