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

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