Elasticsearch 有未分配的分片 详细思路

时间:2022-07-21 00:59:01

Elasticsearch 有未分配的分片通常意味着某些节点无法分配索引分片,这可能会导致搜索和写入的延迟或失败。以下是排查和处理 Elasticsearch 未分配分片的步骤:

  1. 使用 Elasticsearch API 检查集群状态:使用以下 API 获取集群的状态信息:
GET /_cluster/health

如果有未分配的分片,该 API 将返回一个黄色或红色的集群状态。黄色表示分片分配正常,但不是所有的主分片都已经分配。红色表示有一个或多个主分片未分配。

  1. 检查日志:查看 Elasticsearch 节点的日志,以了解是否有任何错误或警告。在节点日志中搜索 “unassigned” 关键字,可以找到未分配的分片的原因,例如节点故障、索引设置不正确等。
  2. 使用 Elasticsearch API 确定未分配的分片:使用以下 API 获取未分配的分片列表:
GET /_cat/shards/<index>?h=index,shard,prirep,state,unassigned.reason

其中 ​​<index>​​ 是要检查的索引名称。这个 API 将返回所有未分配的分片以及原因,例如节点故障、索引设置不正确等。

  1. 解决未分配的分片:一旦确定了未分配的分片,可以采取以下措施:
  • 如果是节点故障造成的未分配,可以修复节点或添加新节点。
  • 如果是索引设置不正确造成的未分配,可以更改索引设置以便正确分配分片。
  • 如果是其他原因造成的未分配,可以根据日志中提供的信息采取相应的措施。
  1. 重新平衡分片:一旦解决了未分配的分片,可以使用以下 API 强制重新平衡分片:
POST /_cluster/reroute?retry_failed=true

这个 API 将强制 Elasticsearch 重新分配所有未分配的分片,并将它们分配给适当的节点。

通过以上步骤,您可以成功排查和处理 Elasticsearch 未分配分片的问题。