--- title: "源分片 routingEntry 不是活跃的主分片 - 如何解决此 Elasticsearch 异常" date: 2026-03-27 lastmod: 2026-03-27 description: "当 Elasticsearch 尝试在非活跃主分片上执行操作时,会出现此错误。本文介绍原因及解决方案。" tags: ["分片管理", "主分片", "异常处理"] summary: "版本: 6.8-8.9 简而言之,当 Elasticsearch 尝试在非活跃主分片上执行操作时,会出现此错误。这可能是由于网络分区、节点故障或分片重新定位导致的。要解决此问题,您可以尝试以下方法:1) 检查集群运行状况,确保所有节点都正常运行。2) 验证分片分配,确保主分片处于活跃状态。3) 如果主分片未处于活跃状态,您可能需要手动重新路由分片或重启节点。4) 确保集群有足够的资源来处理负载。 日志上下文 # 日志 “source shard [” + routingEntry + “] is not an active primary” 的类名是 PeerRecoverySourceService.java。我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入上下文的人参考: final IndexShard shard = indexService.getShard(request.shardId().id()); final ShardRouting routingEntry = shard.routingEntry(); if (routingEntry.primary() == false || routingEntry.active() == false) { throw new DelayRecoveryException("source shard [" + routingEntry + "] is not an active primary"); } if (request.isPrimaryRelocation() && (routingEntry.relocating() == false || routingEntry." --- > **版本:** 6.8-8.9 简而言之,当 Elasticsearch 尝试在非活跃主分片上执行操作时,会出现此错误。这可能是由于网络分区、节点故障或分片重新定位导致的。要解决此问题,您可以尝试以下方法:1) 检查集群运行状况,确保所有节点都正常运行。2) 验证分片分配,确保主分片处于活跃状态。3) 如果主分片未处于活跃状态,您可能需要手动重新路由分片或重启节点。4) 确保集群有足够的资源来处理负载。 ## 日志上下文 日志 "source shard [" + routingEntry + "] is not an active primary" 的类名是 [PeerRecoverySourceService.java](https://www.geeksforgeeks.org/java-lang-class-class-java-set-1/)。我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入上下文的人参考: ```java final IndexShard shard = indexService.getShard(request.shardId().id()); final ShardRouting routingEntry = shard.routingEntry(); if (routingEntry.primary() == false || routingEntry.active() == false) { throw new DelayRecoveryException("source shard [" + routingEntry + "] is not an active primary"); } if (request.isPrimaryRelocation() && (routingEntry.relocating() == false || routingEntry.relocatingNodeId().equals(request.targetNode().getId()) == false)) { logger.debug( ```