版本: 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);
}
}





