--- title: "只读模式下添加索引块请求未被确认 – 如何解决此 Elasticsearch 异常" date: 2026-03-08 lastmod: 2026-03-08 description: "Elasticsearch 因磁盘空间不足进入只读模式时,添加索引块请求未被确认的错误及解决方案" tags: ["只读模式", "磁盘空间", "索引管理", "集群配置"] summary: " 版本: 7.11-8.9 简而言之,当 Elasticsearch 因磁盘空间不足而进入只读模式时,会发生此错误。当磁盘空间严重不足时,Elasticsearch 会自动将索引设置为只读以防止数据丢失。要解决此问题,您可以释放磁盘空间或更改集群设置。要更改设置,请使用 Elasticsearch API 将 “cluster.routing.allocation.disk.watermark.flood_stage” 设置为更高的值或禁用它。但请注意,如果磁盘已满,这可能会导致数据丢失。 日志上下文 # 日志 “read only add block index request failed to be acknowledged” 的类名是 ReadOnlyStep.java. 我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入上下文的人参考: .execute( AddIndexBlockAction.INSTANCE; new AddIndexBlockRequest(WRITE; indexMetadata.getIndex().getName()).masterNodeTimeout(TimeValue.MAX_VALUE); listener.delegateFailureAndWrap((l; response) -> { if (response.isAcknowledged() == false) { throw new ElasticsearchException("read only add block index request failed to be acknowledged"); } l.onResponse(null); }) ); } " --- > **版本:** 7.11-8.9 简而言之,当 Elasticsearch 因磁盘空间不足而进入只读模式时,会发生此错误。当磁盘空间严重不足时,Elasticsearch 会自动将索引设置为只读以防止数据丢失。要解决此问题,您可以释放磁盘空间或更改集群设置。要更改设置,请使用 Elasticsearch API 将 "cluster.routing.allocation.disk.watermark.flood_stage" 设置为更高的值或禁用它。但请注意,如果磁盘已满,这可能会导致数据丢失。 日志上下文 ----------- 日志 "read only add block index request failed to be acknowledged" 的类名是 [ReadOnlyStep.java.](https://www.geeksforgeeks.org/java-lang-class-class-java-set-1/) 我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入上下文的人参考: ```java .execute( AddIndexBlockAction.INSTANCE; new AddIndexBlockRequest(WRITE; indexMetadata.getIndex().getName()).masterNodeTimeout(TimeValue.MAX_VALUE); listener.delegateFailureAndWrap((l; response) -> { if (response.isAcknowledged() == false) { throw new ElasticsearchException("read only add block index request failed to be acknowledged"); } l.onResponse(null); }) ); } ```