Refactor get methods (elastic/elasticsearch#747)
Original commit: elastic/x-pack-elasticsearch@d300be2dde
This commit is contained in:
parent
b2917376f0
commit
4c0d2a492d
|
@ -85,7 +85,9 @@ import java.util.Optional;
|
||||||
import java.util.concurrent.CountDownLatch;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
import java.util.function.BiConsumer;
|
import java.util.function.BiConsumer;
|
||||||
|
import java.util.function.BiFunction;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
public class JobProvider {
|
public class JobProvider {
|
||||||
private static final Logger LOGGER = Loggers.getLogger(JobProvider.class);
|
private static final Logger LOGGER = Loggers.getLogger(JobProvider.class);
|
||||||
|
@ -285,18 +287,24 @@ public class JobProvider {
|
||||||
* @param jobId The job id
|
* @param jobId The job id
|
||||||
*/
|
*/
|
||||||
public void dataCounts(String jobId, Consumer<DataCounts> handler, Consumer<Exception> errorHandler) {
|
public void dataCounts(String jobId, Consumer<DataCounts> handler, Consumer<Exception> errorHandler) {
|
||||||
|
get(jobId, DataCounts.TYPE.getPreferredName(), jobId + DataCounts.DOCUMENT_SUFFIX, handler, errorHandler,
|
||||||
|
DataCounts.PARSER, () -> new DataCounts(jobId));
|
||||||
|
}
|
||||||
|
|
||||||
|
private <T, U> void get(String jobId, String type, String id, Consumer<T> handler, Consumer<Exception> errorHandler,
|
||||||
|
BiFunction<XContentParser, U, T> objectParser, Supplier<T> notFoundSupplier) {
|
||||||
String indexName = AnomalyDetectorsIndex.jobResultsIndexName(jobId);
|
String indexName = AnomalyDetectorsIndex.jobResultsIndexName(jobId);
|
||||||
GetRequest getRequest = new GetRequest(indexName, DataCounts.TYPE.getPreferredName(), jobId + DataCounts.DOCUMENT_SUFFIX);
|
GetRequest getRequest = new GetRequest(indexName, type, id);
|
||||||
client.get(getRequest, ActionListener.wrap(
|
client.get(getRequest, ActionListener.wrap(
|
||||||
response -> {
|
response -> {
|
||||||
if (response.isExists() == false) {
|
if (response.isExists() == false) {
|
||||||
handler.accept(new DataCounts(jobId));
|
handler.accept(notFoundSupplier.get());
|
||||||
} else {
|
} else {
|
||||||
BytesReference source = response.getSourceAsBytesRef();
|
BytesReference source = response.getSourceAsBytesRef();
|
||||||
try (XContentParser parser = XContentFactory.xContent(source).createParser(NamedXContentRegistry.EMPTY, source)) {
|
try (XContentParser parser = XContentFactory.xContent(source).createParser(NamedXContentRegistry.EMPTY, source)) {
|
||||||
handler.accept(DataCounts.PARSER.apply(parser, null));
|
handler.accept(objectParser.apply(parser, null));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new ElasticsearchParseException("failed to parse bucket", e);
|
throw new ElasticsearchParseException("failed to parse " + type, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -309,6 +317,25 @@ public class JobProvider {
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private <T, U> Optional<T> getBlocking(String indexName, String type, String id, BiFunction<XContentParser, U, T> objectParser) {
|
||||||
|
GetRequest getRequest = new GetRequest(indexName, type, id);
|
||||||
|
try {
|
||||||
|
GetResponse response = client.get(getRequest).actionGet();
|
||||||
|
if (!response.isExists()) {
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
BytesReference source = response.getSourceAsBytesRef();
|
||||||
|
try (XContentParser parser = XContentFactory.xContent(source).createParser(NamedXContentRegistry.EMPTY, source)) {
|
||||||
|
return Optional.of(objectParser.apply(parser, null));
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new ElasticsearchParseException("failed to parse " + type, e);
|
||||||
|
}
|
||||||
|
} catch (IndexNotFoundException e) {
|
||||||
|
LOGGER.error("Missing index when getting " + type, e);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search for buckets with the parameters in the {@link BucketsQueryBuilder}
|
* Search for buckets with the parameters in the {@link BucketsQueryBuilder}
|
||||||
*/
|
*/
|
||||||
|
@ -771,32 +798,15 @@ public class JobProvider {
|
||||||
*/
|
*/
|
||||||
public Optional<Quantiles> getQuantiles(String jobId) {
|
public Optional<Quantiles> getQuantiles(String jobId) {
|
||||||
String indexName = AnomalyDetectorsIndex.jobStateIndexName();
|
String indexName = AnomalyDetectorsIndex.jobStateIndexName();
|
||||||
try {
|
|
||||||
String quantilesId = Quantiles.quantilesId(jobId);
|
String quantilesId = Quantiles.quantilesId(jobId);
|
||||||
|
|
||||||
LOGGER.trace("ES API CALL: get ID {} type {} from index {}", quantilesId, Quantiles.TYPE.getPreferredName(), indexName);
|
LOGGER.trace("ES API CALL: get ID {} type {} from index {}", quantilesId, Quantiles.TYPE.getPreferredName(), indexName);
|
||||||
GetRequest getRequest = new GetRequest(indexName, Quantiles.TYPE.getPreferredName(), quantilesId);
|
|
||||||
// can be blocking as it is called from a thread from generic pool:
|
Optional<Quantiles> quantiles = getBlocking(indexName, Quantiles.TYPE.getPreferredName(), quantilesId, Quantiles.PARSER);
|
||||||
GetResponse response = client.get(getRequest).actionGet();
|
if (quantiles.isPresent() && quantiles.get().getQuantileState() == null) {
|
||||||
if (!response.isExists()) {
|
LOGGER.error("Inconsistency - no " + Quantiles.QUANTILE_STATE + " field in quantiles for job " + jobId);
|
||||||
LOGGER.info("There are currently no quantiles for job " + jobId);
|
|
||||||
return Optional.empty();
|
|
||||||
}
|
|
||||||
BytesReference source = response.getSourceAsBytesRef();
|
|
||||||
try (XContentParser parser = XContentFactory.xContent(source).createParser(NamedXContentRegistry.EMPTY, source)) {
|
|
||||||
Quantiles quantiles = Quantiles.PARSER.apply(parser, null);
|
|
||||||
if (quantiles.getQuantileState() == null) {
|
|
||||||
LOGGER.error("Inconsistency - no " + Quantiles.QUANTILE_STATE
|
|
||||||
+ " field in quantiles for job " + jobId);
|
|
||||||
}
|
|
||||||
return Optional.of(quantiles);
|
|
||||||
} catch (IOException e) {
|
|
||||||
throw new ElasticsearchParseException("failed to parse quantiles", e);
|
|
||||||
}
|
|
||||||
} catch (IndexNotFoundException e) {
|
|
||||||
LOGGER.error("Missing index when getting quantiles", e);
|
|
||||||
throw e;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return quantiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1002,33 +1012,15 @@ public class JobProvider {
|
||||||
* Get the job's model size stats.
|
* Get the job's model size stats.
|
||||||
*/
|
*/
|
||||||
public void modelSizeStats(String jobId, Consumer<ModelSizeStats> handler, Consumer<Exception> errorHandler) {
|
public void modelSizeStats(String jobId, Consumer<ModelSizeStats> handler, Consumer<Exception> errorHandler) {
|
||||||
String indexName = AnomalyDetectorsIndex.jobResultsIndexName(jobId);
|
LOGGER.trace("ES API CALL: get result type {} ID {} for job {}",
|
||||||
LOGGER.trace("ES API CALL: get result type {} ID {} from index {}",
|
ModelSizeStats.RESULT_TYPE_VALUE, ModelSizeStats.RESULT_TYPE_FIELD, jobId);
|
||||||
ModelSizeStats.RESULT_TYPE_VALUE, ModelSizeStats.RESULT_TYPE_FIELD, indexName);
|
|
||||||
|
|
||||||
GetRequest getRequest =
|
get(jobId, Result.TYPE.getPreferredName(), ModelSizeStats.RESULT_TYPE_FIELD.getPreferredName(),
|
||||||
new GetRequest(indexName, Result.TYPE.getPreferredName(), ModelSizeStats.RESULT_TYPE_FIELD.getPreferredName());
|
handler, errorHandler, (parser, context) -> ModelSizeStats.PARSER.apply(parser, null).build(),
|
||||||
client.get(getRequest, ActionListener.wrap(response -> {
|
() -> {
|
||||||
if (response.isExists()) {
|
LOGGER.warn("No memory usage details for job with id {}", jobId);
|
||||||
BytesReference source = response.getSourceAsBytesRef();
|
return null;
|
||||||
try (XContentParser parser = XContentFactory.xContent(source).createParser(NamedXContentRegistry.EMPTY, source)) {
|
});
|
||||||
ModelSizeStats modelSizeStats = ModelSizeStats.PARSER.apply(parser, null).build();
|
|
||||||
handler.accept(modelSizeStats);
|
|
||||||
} catch (IOException e) {
|
|
||||||
throw new ElasticsearchParseException("failed to parse model size stats", e);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
String msg = "No memory usage details for job with id " + jobId;
|
|
||||||
LOGGER.warn(msg);
|
|
||||||
handler.accept(null);
|
|
||||||
}
|
|
||||||
}, e -> {
|
|
||||||
if (e instanceof IndexNotFoundException) {
|
|
||||||
handler.accept(null);
|
|
||||||
} else {
|
|
||||||
errorHandler.accept(e);
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1038,19 +1030,7 @@ public class JobProvider {
|
||||||
* @return the matching list if it exists
|
* @return the matching list if it exists
|
||||||
*/
|
*/
|
||||||
public Optional<ListDocument> getList(String listId) {
|
public Optional<ListDocument> getList(String listId) {
|
||||||
GetRequest getRequest = new GetRequest(ML_INFO_INDEX, ListDocument.TYPE.getPreferredName(), listId);
|
return getBlocking(ML_INFO_INDEX, ListDocument.TYPE.getPreferredName(), listId, ListDocument.PARSER);
|
||||||
// can be blocking as it is called from a thread from generic pool:
|
|
||||||
GetResponse response = client.get(getRequest).actionGet();
|
|
||||||
if (!response.isExists()) {
|
|
||||||
return Optional.empty();
|
|
||||||
}
|
|
||||||
BytesReference source = response.getSourceAsBytesRef();
|
|
||||||
try (XContentParser parser = XContentFactory.xContent(source).createParser(NamedXContentRegistry.EMPTY, source)) {
|
|
||||||
ListDocument listDocument = ListDocument.PARSER.apply(parser, null);
|
|
||||||
return Optional.of(listDocument);
|
|
||||||
} catch (IOException e) {
|
|
||||||
throw new ElasticsearchParseException("failed to parse list", e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue