go 遇到的坑

go 查询es报错:

一、问题描述:

elasticsearch 分页查询数据,刚开始数据还可以正常显示,但是到后面就报错:

panic: elastic: Error 400 (Bad Request): all shards failed [type=search_phase_execution_exception]

  

二、原因分析:

搜索了下,有什么 ElasticSearch排序引起的all shards failed异常原因分析? 解决方案
还有就是跟我这个问题一样的,不是因排序引起all shards failed异常,知道了:ES是默认返回1万条数据的。那我遇到的问题就是数据量太大了,超出了ES的最大限制。

 

三、解决方案:

Elasticsearch设置最大返回条数:
在Elasticsearch中如果需要做分页查询,我们通常使用form和size实现。form指定从有序哪一行开始,size表示从当前开始读取多少行。但是我们发现查询结果最大只能到10000,这是因为Elasticsearch中的size的默认值在index.max_result_window 中设置,并且默认值就是10000。下面我们通过Elasticsearch的API设置最大的读取行。
 注:Elasticsearch支持的最大值是2^31-1,也就是2147483647。

put /api.yungehuo.com*/_settings
{
  "index":{
    "max_result_window":2147483647
  }
}

  

 

posted @ 2020-10-16 15:53  枯藤老艹树  阅读(2963)  评论(0编辑  收藏  举报