📣 极限科技诚招搜索运维工程师(Elasticsearch/Easysearch)- 全职/北京 👉 : 立即申请加入

版本: 6.8-8.9

简而言之,当 Elasticsearch 查询的 terms 聚合中的 ‘required_size’ 和 ‘shard_size’ 参数设置为 0 或更小时,会出现此错误。这些参数分别控制返回的唯一术语数量和每个分片要考虑的唯一术语数量。要解决此问题,请确保将这两个参数都设置为正整数。如果不想限制术语数量,可以将这些参数设置为一个非常大的数。

日志上下文 #

日志 “parameters [required_size] and [shard_size] must be >0 in terms aggregation.” 的类名是 TermsAggregator.java. 我们从 Elasticsearch 源代码中提取了以下内容,供那些需要深入了解上下文的人参考:

if (shardMinDocCount > minDocCount) {
 setShardMinDocCount(minDocCount);
 }  if (requiredSize <= 0 || shardSize <= 0) {
 throw new ElasticsearchException("parameters [required_size] and [shard_size] must be >0 in terms aggregation.");
 }  if (minDocCount < 0 || shardMinDocCount < 0) {
 throw new ElasticsearchException("parameter [min_doc_count] and [shardMinDocCount] must be >=0 in terms aggregation.");
 }