[ML] Add notification when no suitable nodes exist to allocate job (elastic/x-pack-elasticsearch#1006)
Relates elastic/x-pack-elasticsearch#878 Original commit: elastic/x-pack-elasticsearch@5a96484662
This commit is contained in:
parent
3986235d93
commit
bf111dde7e
|
@ -405,8 +405,10 @@ public class OpenJobAction extends Action<OpenJobAction.Request, OpenJobAction.R
|
||||||
OpenJobAction.validate(request.getJobId(), mlMetadata, tasks);
|
OpenJobAction.validate(request.getJobId(), mlMetadata, tasks);
|
||||||
Assignment assignment = selectLeastLoadedMlNode(request.getJobId(), clusterState, maxConcurrentJobAllocations, logger);
|
Assignment assignment = selectLeastLoadedMlNode(request.getJobId(), clusterState, maxConcurrentJobAllocations, logger);
|
||||||
if (assignment.getExecutorNode() == null) {
|
if (assignment.getExecutorNode() == null) {
|
||||||
throw new ElasticsearchStatusException("cannot open job [" + request.getJobId() + "], no suitable nodes found, " +
|
String msg = "Could not open job because no suitable nodes were found, allocation explanation ["
|
||||||
"allocation explanation [{}]", RestStatus.TOO_MANY_REQUESTS, assignment.getExplanation());
|
+ assignment.getExplanation() + "]";
|
||||||
|
auditor.warning(request.getJobId(), msg);
|
||||||
|
throw new ElasticsearchStatusException(msg, RestStatus.TOO_MANY_REQUESTS);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
throw LicenseUtils.newComplianceException(XPackPlugin.MACHINE_LEARNING);
|
throw LicenseUtils.newComplianceException(XPackPlugin.MACHINE_LEARNING);
|
||||||
|
@ -447,7 +449,7 @@ public class OpenJobAction extends Action<OpenJobAction.Request, OpenJobAction.R
|
||||||
auditor.warning(jobId, "No node found to open job. Reasons [" + assignment.getExplanation() + "]");
|
auditor.warning(jobId, "No node found to open job. Reasons [" + assignment.getExplanation() + "]");
|
||||||
} else {
|
} else {
|
||||||
DiscoveryNode node = state.nodes().get(assignment.getExecutorNode());
|
DiscoveryNode node = state.nodes().get(assignment.getExecutorNode());
|
||||||
auditor.info(jobId, "Found node [" + node + "] to open job");
|
auditor.info(jobId, "Opening job on node [" + node.toString() + "]");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -465,7 +465,7 @@ public class StartDatafeedAction
|
||||||
assignment.getExplanation() + "]");
|
assignment.getExplanation() + "]");
|
||||||
} else {
|
} else {
|
||||||
DiscoveryNode node = state.nodes().get(assignment.getExecutorNode());
|
DiscoveryNode node = state.nodes().get(assignment.getExecutorNode());
|
||||||
auditor.info(jobId, "Found node [" + node + "] to start datafeed [" + datafeedId + "]");
|
auditor.info(jobId, "Starting datafeed [" + datafeedId + "] on node [" + node + "]");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue