Elasticsearch集群 单个节点分片限制

如果在 Elasticsearch 中单个节点上的分片数量超过了 cluster.max_shards_per_node 设置的限制(默认限制通常是1000分片),Elasticsearch 不会提供一个特定的状态码,而是会拒绝创建新的分片,并返回一个错误消息。这个错误消息通常会在创建索引或分片的 API 调用的 HTTP 响应体中体现,并伴随一个 HTTP 状态码。

在尝试创建超过限制的分片时,你可能会收到类似以下的错误消息:

java 复制代码
{
  "error": {
    "root_cause": [
      {
        "type": "validation_exception",
        "reason": "Validation Failed: 1: this action would add [number] total shards, but this cluster currently has [number]/[limit] maximum shards open;"
      }
    ],
    "type": "validation_exception",
    "reason": "Validation Failed: 1: this action would add [number] total shards, but this cluster currently has [number]/[limit] maximum shards open;"
  },
  "status": 400
}

在这种情况下,HTTP 状态码是 400,表示请求因为不满足验证条件而无法被执行。这个验证异常指出了创建操作将会导致的分片总数超过了集群配置的最大分片数。

要解决这个问题,你可以选择重新设计索引策略,增加节点以分散分片,或者提高 cluster.max_shards_per_node 的配置值。不过,增加分片的上限需要谨慎考虑,因为这可能会导致性能问题或其他稳定性问题。

相关推荐
Elasticsearch20 小时前
Elasticsearch:如何为 Elastic Stack 部署 E5 模型 - 下载及隔离环境
elasticsearch
大数据CLUB20 小时前
酒店预订数据分析及预测可视化
大数据·hadoop·分布式·数据挖掘·数据分析·spark·mapreduce
huisheng_qaq21 小时前
【ElasticSearch实用篇-05】基于脚本script打分
大数据·elasticsearch·script·匹配·社交·脚本打分
极客学术工坊1 天前
2023年第十五届 “电工杯” 大学生数学建模竞赛-B题 人工智能对大学生学习影响的评价-人工智能对大学生学习影响的评价
搜索引擎
夜郎king1 天前
MapTalks:国产轻量化二三维一体化GIS引擎
大数据·国产二三维引擎·maptalks引擎
青鱼入云1 天前
ES脚本语言Painless介绍
大数据·elasticsearch·搜索引擎
Jonathan Star1 天前
嵌套 Git 仓库(Submodule/子模块)
大数据·git·elasticsearch
TDengine (老段)1 天前
从“数据堆场”到“智能底座”:TDengine IDMP如何统一数据语言
大数据·数据库·物联网·时序数据库·tdengine
liuyunshengsir1 天前
让 Elasticsearch Delete By Query 请求立即生效
大数据·elasticsearch·jenkins
武子康1 天前
大数据-148 Flink 写入 Kudu 实战:自定义 Sink 全流程(Flink 1.11/Kudu 1.17/Java 11)
大数据·后端·nosql