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

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