📣 极限科技诚招搜索运维工程师(Elasticsearch/Easysearch)- 全职/北京 👉 : 立即申请加入

版本: 6.8-8.9

简而言之,当 Elasticsearch 无法将更改提交到引擎时会出现此错误,这可能是由于多种原因导致的,例如磁盘空间问题、网络问题或索引损坏。要解决此问题,您可以尝试以下方法:1) 检查是否有足够的磁盘空间,必要时释放空间。2) 检查节点之间的网络连接。3) 尝试修复损坏的索引或从备份中恢复它们。4) 如果问题仍然存在,考虑重启 Elasticsearch 节点。

日志上下文 #

日志 “failed to commit engine” 的类名是 InternalEngine.java。我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入了解上下文的人参考:

/*
 * 如果启用了断言;如果任何文件不存在,IndexWriter 在提交时会抛出 AssertionError;
 * 但随机抛出 FileNotFoundException 或 NoSuchFileException 的测试也可能遇到这种情况。
 */
if (ExceptionsHelper.stackTrace(e).contains("org.apache.lucene.index.IndexWriter.filesExist")) {
    final EngineException engineException = new EngineException(shardId, "failed to commit engine", e);
    try {
        failEngine("lucene commit failed", engineException);
    } catch (final Exception inner) {
        engineException.addSuppressed(inner);
    }
}