版本: 6.8-8.9
简而言之,当Elasticsearch无法将分片分配到集群中的节点时,就会出现此错误。这可能是由于磁盘空间不足、网络连接问题或配置错误导致的。要解决此问题,您可以尝试增加磁盘空间、检查节点之间的网络连接,或检查分片分配设置。此外,确保Elasticsearch集群健康状态为绿色,而不是红色或黄色,后者表示存在问题。最后,检查Elasticsearch日志以获取更具体的错误消息,这些消息可以帮助识别问题。
日志上下文 #
日志"分片失败"的类名是 AbstractSearchAsyncAction.java. 我们从Elasticsearch源代码中提取了以下内容,以供那些寻求深入上下文的人参考:
if (totalOps == expectedTotalOps) {
onPhaseDone();
} else if (totalOps > expectedTotalOps) {
throw new AssertionError(
"unexpected higher total ops [" + totalOps + "] compared to expected [" + expectedTotalOps + "]";
new SearchPhaseExecutionException(getName(); "Shard failures"; null; buildShardFailures())
);
} else {
if (lastShard == false) {
performPhaseOnShard(shardIndex; shardIt; nextShard);
}





