版本: 6.8-7.15
简而言之,当 Elasticsearch 由于分片分配问题而无法启动 datafeed 时,会出现此错误。这可能是由于磁盘空间不足、节点故障或配置问题造成的。要解决此问题,您可以检查集群健康状况并确保所有节点正常运行。如果是磁盘空间问题,请考虑删除不必要的索引或增加磁盘空间。如果是配置问题,请检查并更正您的分片分配设置。
日志上下文 #
日志 “Could not start datafeed; allocation explanation [” 的类名是 TransportStartDatafeedAction.java。 我们从 Elasticsearch 源代码中提取了以下内容,供那些寻求深入上下文的人参考:
if (assignment.equals(DatafeedNodeSelector.AWAITING_JOB_RELOCATION)) {
return true;
}
if (assignment.equals(PersistentTasksCustomMetadata.INITIAL_ASSIGNMENT) == false && assignment.isAssigned() == false) {
// Assignment has failed despite passing our "fast fail" validation
exception = new ElasticsearchStatusException("Could not start datafeed; allocation explanation [" +
assignment.getExplanation() + "]", RestStatus.TOO_MANY_REQUESTS);
return true;
}
}
DatafeedState datafeedState = (DatafeedState) persistentTask.getState();





