Elasticsearch 报错:index read-only / allow delete (api) 深度解析与解决方案

sh 复制代码
ClusterBlockException[index [.monitoring-es-7-2025.11.12] blocked by: [FORBIDDEN/12/index read-only / allow delete (api)]]

🚨 Elasticsearch 报错:index read-only / allow delete (api) 深度解析与解决方案

💡 关键词:Elasticsearch、磁盘空间不足、监控索引、只读状态


一、问题背景

在一次 Node.js 项目运行过程中,我们的 Elasticsearch 集群突然在日志中疯狂刷出警告:

sh 复制代码
"message": "unexpected error while indexing monitoring document",
"stacktrace": [
  "org.elasticsearch.xpack.monitoring.exporter.ExportException: ClusterBlockException[index [.monitoring-es-7-2025.11.12] blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];]"
]

Kibana 监控页面无法更新,ES 指标面板停止刷新。

但奇怪的是,我们清理了磁盘空间后,问题仍然存在。


二、问题现象

执行 GET _cat/indices?v,可以看到 .monitoring-* 索引状态为 green,但日志仍不断报:

sh 复制代码
index [.monitoring-es-7-2025.11.12] blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];

即使空间已经恢复,Elasticsearch 仍然拒绝对这些索引写入。


三、问题根因分析

1️⃣ Elasticsearch 的自动保护机制

当磁盘使用率超过阈值(默认 95%),ES 会自动触发保护机制:

sh 复制代码
index.blocks.read_only_allow_delete = true

意思是:

• 索引变为只读;

• 只允许删除(防止磁盘被完全写满导致崩溃)。

这是一种「自我保护」,以防止数据写满磁盘导致节点宕机。


2️⃣ 清理空间 ≠ 自动解除锁定

即使你清理了磁盘空间,Elasticsearch 不会自动解锁索引。

这点经常让人误以为"磁盘问题还没解决",其实只是索引状态没恢复。


3️⃣ 监控索引的特殊性

报错中的 .monitoring-es-* 和 .monitoring-kibana-* 属于 X-Pack Monitoring 模块。

Kibana、Metricbeat 等监控数据会持续往这些索引写入。

只要它们被锁定,就会持续抛出 "unexpected error while indexing monitoring document"。


四、解决步骤 ✅

  1. 查看索引只读状态

执行以下命令查看哪些索引被锁定:

sh 复制代码
GET _all/_settings?filter_path=**.blocks.read_only_allow_delete

你会看到类似输出:

sh 复制代码
{
  ".monitoring-es-7-2025.11.12": {
    "settings": {
      "index.blocks.read_only_allow_delete": "true"
    }
  }
}

  1. 清理磁盘空间

  1. 解锁索引

解锁单个索引:

sh 复制代码
PUT .monitoring-es-7-2025.11.12/_settings
{
  "index.blocks.read_only_allow_delete": null
}

或者解锁所有索引(推荐):

sh 复制代码
PUT _all/_settings
{
  "index.blocks.read_only_allow_delete": null
}
  1. 验证结果

再次执行:

sh 复制代码
GET _cat/indices?v

监控索引恢复正常写入后,日志中的 FORBIDDEN/12 报错将停止。


  1. (可选)清理旧监控索引

这些 .monitoring-* 索引每天会自动创建一个新索引(按日期)。

可以清理过期数据节省空间:

sh 复制代码
DELETE .monitoring-es-7-2025.10*
DELETE .monitoring-kibana-7-2025.10*

或者在 elasticsearch.yml 中关闭自动监控:

sh 复制代码
xpack.monitoring.enabled: false

五、延伸:为什么清理磁盘后错误还在?

这是很多人困惑的点。

Elasticsearch 判断磁盘"安全"需要两个条件:

  1. 实际磁盘使用率低于 cluster.routing.allocation.disk.watermark.low(默认 85%);

  2. 索引解除只读状态。

即使你释放了空间,只要第 2 步没做,仍然会报 index read-only / allow delete (api)。


六、总结

问题 原因 解决
报错 FORBIDDEN/12 磁盘满导致索引只读 PUT _all/_settings 解锁
清理磁盘仍报错 ES 不会自动解锁索引 手动恢复只读状态
.monitoring-* 报错 Kibana/ES 自带监控无法写入 解锁或清理监控索引
日志持续警告 未清理旧索引 删除历史 .monitoring-*

七、实战命令汇总

sh 复制代码
# 查看集群磁盘状态
GET _cluster/stats?human

# 查看只读索引
GET _all/_settings?filter_path=**.blocks.read_only_allow_delete

# 全量解锁
PUT _all/_settings
{
  "index.blocks.read_only_allow_delete": null
}

# 删除旧监控索引
DELETE .monitoring-es-7-2025.10*
DELETE .monitoring-kibana-7-2025.10*
相关推荐
智慧景区与市集主理人9 小时前
五一乡村文旅增收难?巨有科技大数据双赋能破局突围
大数据·科技
TechubNews12 小时前
新火集团首席经济学家付鹏演讲——2026 年是 Crypto 加入到 FICC 资产配置框架元年
大数据·人工智能
Elastic 中国社区官方博客13 小时前
为 Elastic Cloud Serverless 和 Elasticsearch 引入统一的 API 密钥
大数据·运维·elasticsearch·搜索引擎·云原生·serverless
vastsmile15 小时前
(R)26.04.23 hermes agent执行本地命令超级慢的原因
开发语言·elasticsearch·r语言
CS创新实验室16 小时前
CS实验室行业报告:机器人领域就业分析报告
大数据·人工智能·机器人
LinuxGeek102419 小时前
Kylin-Server-V11、openEuler-22.03和openEuler-24.03的MySQL 9.7.0版本正式发布
大数据·mysql·kylin
容智信息19 小时前
国家级算力底座+企业级智能体:容智Agent OS 获选入驻移动云能中心,联手赋能千行百业
大数据·人工智能·自然语言处理·智慧城市
Chuer_20 小时前
讲透财务Agent核心概念,深度拆解财务Agent应用趋势
大数据·数据库·安全·数据分析·甘特图
gushinghsjj20 小时前
什么是主数据管理平台?怎么构建主数据管理平台?
大数据·数据库
焦糖玛奇朵婷20 小时前
解锁扭蛋机小程序的五大优势
java·大数据·服务器·前端·小程序