版本: 7.2-7.4
简要来说,当Elasticsearch由于资源不足或分配不当无法启动data frame analytics作业时,就会出现此错误。这可能是由于磁盘空间不足、内存不足或节点分配不正确造成的。要解决此问题,您可以尝试增加磁盘空间或内存,检查节点分配设置,或在多个节点之间重新分配负载。此外,确保Elasticsearch集群配置正确,并且没有网络连接问题。
日志上下文 #
日志"Could not start dataframe; allocation explanation [“的类名是 TransportStartDataFrameTransformAction.java。我们从Elasticsearch源代码中提取了以下内容,供那些寻求深入上下文的人参考:
if (assignment != null &&
assignment.equals(PersistentTasksCustomMetaData.INITIAL_ASSIGNMENT) == false &&
assignment.isAssigned() == false) {
// For some reason, the task is not assigned to a node, but is no longer in the `INITIAL_ASSIGNMENT` state
// Consider this a failure.
exception = new ElasticsearchStatusException("Could not start dataframe; allocation explanation [" +
assignment.getExplanation() + "]", RestStatus.TOO_MANY_REQUESTS);
return true;
}
// We just want it assigned so we can tell it to start working
return assignment != null && assignment.isAssigned() && isNotStopped(persistentTask);





