[ML] Only attempt to get the native code version when ML is enabled (elastic/x-pack-elasticsearch#1346)
Originally we used to try to get the native code version even when ML was disabled. However, this has proved to be an annoyance in cases where people running on unsupported platforms have disabled ML. This commit means we'll only try to get the native code version if ML is enabled on a node. Original commit: elastic/x-pack-elasticsearch@778d6708d2
This commit is contained in:
parent
0c4a7e1930
commit
9264ad541e
|
@ -70,10 +70,12 @@ public class MachineLearningFeatureSet implements XPackFeatureSet {
|
|||
this.client = Objects.requireNonNull(client);
|
||||
this.licenseState = licenseState;
|
||||
Map<String, Object> nativeCodeInfo = NativeController.UNKNOWN_NATIVE_CODE_INFO;
|
||||
// Don't try to get the native code version in the transport client - the controller process won't be running
|
||||
if (XPackPlugin.transportClientMode(settings) == false && XPackPlugin.isTribeClientNode(settings) == false) {
|
||||
// Don't try to get the native code version if ML is disabled - it causes too much controversy
|
||||
// if ML has been disabled because of some OS incompatibility. Also don't try to get the native
|
||||
// code version in the transport or tribe client - the controller process won't be running.
|
||||
if (enabled && XPackPlugin.transportClientMode(settings) == false && XPackPlugin.isTribeClientNode(settings) == false) {
|
||||
try {
|
||||
if (isRunningOnMlPlatform(enabled)) {
|
||||
if (isRunningOnMlPlatform(true)) {
|
||||
NativeController nativeController = NativeControllerHolder.getNativeController(settings);
|
||||
if (nativeController != null) {
|
||||
nativeCodeInfo = nativeController.getNativeCodeInfo();
|
||||
|
@ -81,11 +83,9 @@ public class MachineLearningFeatureSet implements XPackFeatureSet {
|
|||
}
|
||||
} catch (IOException | TimeoutException e) {
|
||||
Loggers.getLogger(MachineLearningFeatureSet.class).error("Cannot get native code info for Machine Learning", e);
|
||||
if (enabled) {
|
||||
throw new ElasticsearchException("Cannot communicate with Machine Learning native code");
|
||||
}
|
||||
}
|
||||
}
|
||||
this.nativeCodeInfo = nativeCodeInfo;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue