MetricsAdvisorAsyncClient Class
- java.
lang. Object - com.
azure. ai. metricsadvisor. MetricsAdvisorAsyncClient
- com.
public final class MetricsAdvisorAsyncClient
This class provides an asynchronous client to connect to the Metrics Advisor Azure Cognitive Service.
This client provides asynchronous methods to perform:
- Analyze root cause into specific dimension using the com.azure.ai.metricsadvisor.MetricsAdvisorAsyncClient#listIncidentRootCauses(String, String) method with your respective data source.
- Fetch incidents triggered for a particular detection configuration using the com.azure.ai.metricsadvisor.MetricsAdvisorAsyncClient#listIncidentsForDetectionConfig(String, OffsetDateTime, OffsetDateTime) method.
- Fetch all the anomalies detected for a particular detection configuration using the com.azure.ai.metricsadvisor.MetricsAdvisorAsyncClient#listAnomaliesForDetectionConfig(String, OffsetDateTime, OffsetDateTime) method./li>
Service clients are the point of interaction for developers to use Azure Metrics Advisor. MetricsAdvisorClient is the synchronous service client and MetricsAdvisorAsyncClient is the asynchronous service client. The examples shown in this document use a credential object named DefaultAzureCredential for authentication, which is appropriate for most scenarios, including local development and production environments. Additionally, we recommend using managed identity for authentication in production environments. You can find more information on different ways of authenticating and their corresponding credential types in the Azure Identity documentation".
Sample: Construct a MetricsAdvisorAsyncClient with DefaultAzureCredential
The following code sample demonstrates the creation of a MetricsAdvisorAsyncClient, using the `DefaultAzureCredentialBuilder` to configure it.
MetricsAdvisorAsyncClient metricsAdvisorAsyncClient =
new MetricsAdvisorClientBuilder()
.credential(new DefaultAzureCredentialBuilder().build())
.endpoint("{endpoint}")
.buildAsyncClient();
Further, see the code sample below to use MetricsAdvisorKeyCredential for client creation.
MetricsAdvisorAsyncClient metricsAdvisorAsyncClient =
new MetricsAdvisorClientBuilder()
.credential(new MetricsAdvisorKeyCredential("{subscription_key}", "{api_key}"))
.endpoint("{endpoint}")
.buildAsyncClient();
Method Summary
Methods inherited from java.lang.Object
Method Details
addFeedback
public Mono
Create a new metric feedback.
Code sample
final String metricId = "d3gh4i4-b804-4ab9-a70f-0da0c89cft3l";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final MetricChangePointFeedback metricChangePointFeedback
= new MetricChangePointFeedback(startTime, endTime, ChangePointValue.AUTO_DETECT);
metricsAdvisorAsyncClient.addFeedback(metricId, metricChangePointFeedback)
.subscribe(metricFeedback -> {
MetricChangePointFeedback createdMetricChangePointFeedback = (MetricChangePointFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback Id: %s%n", createdMetricChangePointFeedback.getId());
System.out.printf("Data Feed Metric feedback change point value: %s%n",
createdMetricChangePointFeedback.getChangePointValue().toString());
System.out.printf("Data Feed Metric feedback start time: %s%n",
createdMetricChangePointFeedback.getStartTime());
System.out.printf("Data Feed Metric feedback end time: %s%n",
createdMetricChangePointFeedback.getEndTime());
});
Parameters:
Returns:
addFeedbackWithResponse
public Mono
Create a new metric feedback.
Code sample
final String metricId = "d3gh4i4-b804-4ab9-a70f-0da0c89cft3l";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final MetricChangePointFeedback metricChangePointFeedback
= new MetricChangePointFeedback(startTime, endTime, ChangePointValue.AUTO_DETECT);
metricsAdvisorAsyncClient.addFeedbackWithResponse(metricId, metricChangePointFeedback)
.subscribe(metricFeedbackResponse -> {
System.out.printf("Data Feed Metric feedback creation operation status %s%n",
metricFeedbackResponse.getStatusCode());
MetricChangePointFeedback createdMetricChangePointFeedback
= (MetricChangePointFeedback) metricFeedbackResponse.getValue();
System.out.printf("Data Feed Metric feedback Id: %s%n", createdMetricChangePointFeedback.getId());
System.out.printf("Data Feed Metric feedback change point value: %s%n",
createdMetricChangePointFeedback.getChangePointValue().toString());
System.out.printf("Data Feed Metric feedback start time: %s%n",
createdMetricChangePointFeedback.getStartTime());
System.out.printf("Data Feed Metric feedback end time: %s%n",
createdMetricChangePointFeedback.getEndTime());
System.out.printf("Data Feed Metric feedback associated dimension filter: %s%n",
createdMetricChangePointFeedback.getDimensionFilter().asMap());
});
Parameters:
Returns:
getFeedback
public Mono
Get a metric feedback by its id.
Code sample
final String feedbackId = "8i3h4i4-b804-4ab9-a70f-0da0c89cft3l";
metricsAdvisorAsyncClient.getFeedback(feedbackId)
.subscribe(metricFeedback -> {
System.out.printf("Data Feed Metric feedback Id: %s%n", metricFeedback.getId());
System.out.printf("Data Feed Metric feedback associated dimension filter: %s%n",
metricFeedback.getDimensionFilter().asMap());
if (PERIOD.equals(metricFeedback.getFeedbackType())) {
MetricPeriodFeedback createMetricPeriodFeedback
= (MetricPeriodFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback type: %s%n",
createMetricPeriodFeedback.getPeriodType().toString());
System.out.printf("Data Feed Metric feedback period value: %d%n",
createMetricPeriodFeedback.getPeriodValue());
}
});
Parameters:
Returns:
getFeedbackWithResponse
public Mono
Get a metric feedback by its id.
Code sample
final String feedbackId = "8i3h4i4-b804-4ab9-a70f-0da0c89cft3l";
metricsAdvisorAsyncClient.getFeedbackWithResponse(feedbackId)
.subscribe(metricFeedbackResponse -> {
final MetricFeedback metricFeedback = metricFeedbackResponse.getValue();
System.out.printf("Data Feed Metric feedback Id: %s%n", metricFeedback.getId());
System.out.printf("Data Feed Metric feedback associated dimension filter: %s%n",
metricFeedback.getDimensionFilter().asMap());
if (PERIOD.equals(metricFeedback.getFeedbackType())) {
MetricPeriodFeedback createMetricPeriodFeedback
= (MetricPeriodFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback type: %s%n",
createMetricPeriodFeedback.getPeriodType().toString());
System.out.printf("Data Feed Metric feedback period value: %d%n",
createMetricPeriodFeedback.getPeriodValue());
}
});
Parameters:
Returns:
listAlerts
public PagedFlux
Fetch the alerts triggered by an anomaly alert configuration.
Code sample
final String alertConfigurationId = "ff3014a0-bbbb-41ec-a637-677e77b81299";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final AlertQueryTimeMode timeMode = AlertQueryTimeMode.ANOMALY_TIME;
metricsAdvisorAsyncClient.listAlerts(alertConfigurationId, startTime, endTime)
.subscribe(alert -> {
System.out.printf("Anomaly Alert Id: %s%n", alert.getId());
System.out.printf("Created Time: %s%n", alert.getCreatedTime());
System.out.printf("Modified Time: %s%n", alert.getModifiedTime());
});
Parameters:
Returns:
listAlerts
public PagedFlux
Fetch the alerts triggered by an anomaly alert configuration.
Code sample
final String alertConfigurationId = "ff3014a0-bbbb-41ec-a637-677e77b81299";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final AlertQueryTimeMode timeMode = AlertQueryTimeMode.ANOMALY_TIME;
final ListAlertOptions options = new ListAlertOptions()
.setAlertQueryTimeMode(timeMode)
.setMaxPageSize(10);
metricsAdvisorAsyncClient.listAlerts(alertConfigurationId, startTime, endTime, options)
.subscribe(alert -> {
System.out.printf("Anomaly Alert Id: %s%n", alert.getId());
System.out.printf("Created Time: %s%n", alert.getCreatedTime());
System.out.printf("Modified Time: %s%n", alert.getModifiedTime());
});
Parameters:
Returns:
listAnomaliesForAlert
public PagedFlux
Fetch the anomalies in an alert.
Code sample
final String alertConfigurationId = "ff3014a0-bbbb-41ec-a637-677e77b81299";
final String alertId = "1746b031c00";
metricsAdvisorAsyncClient.listAnomaliesForAlert(
alertConfigurationId,
alertId)
.subscribe(anomaly -> {
System.out.printf("Data Feed Metric Id: %s%n", anomaly.getMetricId());
System.out.printf("Detection Configuration Id: %s%n", anomaly.getDetectionConfigurationId());
System.out.printf("DataPoint Anomaly Created Time: %s%n", anomaly.getCreatedTime());
System.out.printf("DataPoint Anomaly Modified Time: %s%n", anomaly.getModifiedTime());
System.out.printf("DataPoint Anomaly AnomalySeverity: %s%n", anomaly.getSeverity());
System.out.printf("DataPoint Anomaly Status: %s%n", anomaly.getStatus());
System.out.printf("Series Key:");
DimensionKey seriesKey = anomaly.getSeriesKey();
for (Map.Entry<String, String> dimension : seriesKey.asMap().entrySet()) {
System.out.printf("DimensionName: %s DimensionValue:%s%n",
dimension.getKey(), dimension.getValue());
}
});
Parameters:
Returns:
listAnomaliesForAlert
public PagedFlux
Fetch the anomalies in an alert.
Code sample
final String alertConfigurationId = "ff3014a0-bbbb-41ec-a637-677e77b81299";
final String alertId = "1746b031c00";
final ListAnomaliesAlertedOptions options = new ListAnomaliesAlertedOptions()
.setMaxPageSize(10);
metricsAdvisorAsyncClient.listAnomaliesForAlert(
alertConfigurationId,
alertId,
options)
.subscribe(anomaly -> {
System.out.printf("Data Feed Metric Id: %s%n", anomaly.getMetricId());
System.out.printf("Detection Configuration Id: %s%n", anomaly.getDetectionConfigurationId());
System.out.printf("DataPoint Anomaly Created Time: %s%n", anomaly.getCreatedTime());
System.out.printf("DataPoint Anomaly Modified Time: %s%n", anomaly.getModifiedTime());
System.out.printf("DataPoint Anomaly AnomalySeverity: %s%n", anomaly.getSeverity());
System.out.printf("DataPoint Anomaly Status: %s%n", anomaly.getStatus());
System.out.printf("Series Key:");
System.out.println(anomaly.getSeriesKey().asMap());
});
Parameters:
Returns:
listAnomaliesForDetectionConfig
public PagedFlux
Fetch the anomalies identified by an anomaly detection configuration.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T12:00:00Z");
metricsAdvisorAsyncClient.listAnomaliesForDetectionConfig(detectionConfigurationId,
startTime, endTime)
.subscribe(anomaly -> {
System.out.printf("DataPoint Anomaly AnomalySeverity: %s%n", anomaly.getSeverity());
System.out.printf("Series Key:");
DimensionKey seriesKey = anomaly.getSeriesKey();
for (Map.Entry<String, String> dimension : seriesKey.asMap().entrySet()) {
System.out.printf("DimensionName: %s DimensionValue:%s%n",
dimension.getKey(), dimension.getValue());
}
});
Parameters:
Returns:
listAnomaliesForDetectionConfig
public PagedFlux
Fetch the anomalies identified by an anomaly detection configuration.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T12:00:00Z");
final ListAnomaliesDetectedFilter filter = new ListAnomaliesDetectedFilter()
.setSeverityRange(AnomalySeverity.LOW, AnomalySeverity.MEDIUM);
final ListAnomaliesDetectedOptions options = new ListAnomaliesDetectedOptions()
.setMaxPageSize(10)
.setFilter(filter);
metricsAdvisorAsyncClient.listAnomaliesForDetectionConfig(detectionConfigurationId,
startTime, endTime, options)
.subscribe(anomaly -> {
System.out.printf("DataPoint Anomaly AnomalySeverity: %s%n", anomaly.getSeverity());
System.out.printf("Series Key:");
DimensionKey seriesKey = anomaly.getSeriesKey();
for (Map.Entry<String, String> dimension : seriesKey.asMap().entrySet()) {
System.out.printf("DimensionName: %s DimensionValue:%s%n",
dimension.getKey(), dimension.getValue());
}
});
Parameters:
Returns:
listAnomalyDimensionValues
public PagedFlux
Fetch dimension values that have anomalies.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final String dimensionName = "Dim1";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
metricsAdvisorAsyncClient.listAnomalyDimensionValues(detectionConfigurationId,
dimensionName,
startTime, endTime)
.subscribe(dimensionValue -> {
System.out.printf("DataFeedDimension Value: %s%n", dimensionValue);
});
Parameters:
Returns:
listAnomalyDimensionValues
public PagedFlux
Fetch dimension values that have anomalies.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final String dimensionName = "Dim1";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final ListAnomalyDimensionValuesOptions options
= new ListAnomalyDimensionValuesOptions()
.setMaxPageSize(10);
metricsAdvisorAsyncClient.listAnomalyDimensionValues(detectionConfigurationId,
dimensionName,
startTime, endTime, options)
.subscribe(dimensionValue -> {
System.out.printf("DataFeedDimension Value: %s%n", dimensionValue);
});
Parameters:
Returns:
listFeedback
public PagedFlux
List information of metrics feedback on the account for a metric Id.
Code sample
final String metricId = "d3gh4i4-b804-4ab9-a70f-0da0c89cft3l";
metricsAdvisorAsyncClient.listFeedback(metricId)
.subscribe(metricFeedback -> {
System.out.printf("Data Feed Metric feedback Id: %s%n", metricFeedback.getId());
System.out.printf("Data Feed Metric feedback associated dimension filter: %s%n",
metricFeedback.getDimensionFilter().asMap());
if (PERIOD.equals(metricFeedback.getFeedbackType())) {
MetricPeriodFeedback periodFeedback
= (MetricPeriodFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback type: %s%n",
periodFeedback.getPeriodType().toString());
System.out.printf("Data Feed Metric feedback period value: %d%n",
periodFeedback.getPeriodValue());
} else if (ANOMALY.equals(metricFeedback.getFeedbackType())) {
MetricAnomalyFeedback metricAnomalyFeedback
= (MetricAnomalyFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback anomaly value: %s%n",
metricAnomalyFeedback.getAnomalyValue().toString());
System.out.printf("Data Feed Metric feedback associated detection configuration: %s%n",
metricAnomalyFeedback.getDetectionConfigurationId());
} else if (COMMENT.equals(metricFeedback.getFeedbackType())) {
MetricCommentFeedback metricCommentFeedback
= (MetricCommentFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback comment value: %s%n",
metricCommentFeedback.getComment());
}
});
Parameters:
Returns:
listFeedback
public PagedFlux
List information of all metric feedbacks on the metrics advisor account for a metric Id.
Code sample
final String metricId = "d3gh4i4-b804-4ab9-a70f-0da0c89cft3l";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
metricsAdvisorAsyncClient.listFeedback(metricId,
new ListMetricFeedbackOptions()
.setFilter(new ListMetricFeedbackFilter()
.setStartTime(startTime)
.setTimeMode(FeedbackQueryTimeMode.FEEDBACK_CREATED_TIME)
.setEndTime(endTime)))
.subscribe(metricFeedback -> {
System.out.printf("Data Feed Metric feedback Id: %s%n", metricFeedback.getId());
System.out.printf("Data Feed Metric feedback associated dimension filter: %s%n",
metricFeedback.getDimensionFilter().asMap());
System.out.printf("Data Feed Metric feedback created time %s%n", metricFeedback.getCreatedTime());
if (PERIOD.equals(metricFeedback.getFeedbackType())) {
MetricPeriodFeedback periodFeedback
= (MetricPeriodFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback type: %s%n",
periodFeedback.getPeriodType().toString());
System.out.printf("Data Feed Metric feedback period value: %d%n",
periodFeedback.getPeriodValue());
} else if (ANOMALY.equals(metricFeedback.getFeedbackType())) {
MetricAnomalyFeedback metricAnomalyFeedback
= (MetricAnomalyFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback anomaly value: %s%n",
metricAnomalyFeedback.getAnomalyValue().toString());
System.out.printf("Data Feed Metric feedback associated detection configuration: %s%n",
metricAnomalyFeedback.getDetectionConfigurationId());
} else if (COMMENT.equals(metricFeedback.getFeedbackType())) {
MetricCommentFeedback metricCommentFeedback
= (MetricCommentFeedback) metricFeedback;
System.out.printf("Data Feed Metric feedback comment value: %s%n",
metricCommentFeedback.getComment());
}
});
Parameters:
Returns:
listIncidentRootCauses
public PagedFlux
List the root causes for an anomalyIncident.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final ListIncidentsDetectedOptions options
= new ListIncidentsDetectedOptions()
.setMaxPageSize(10);
metricsAdvisorAsyncClient.listIncidentsForDetectionConfig(detectionConfigurationId, startTime, endTime,
options)
.flatMap(incident -> {
return metricsAdvisorAsyncClient.listIncidentRootCauses(incident);
})
.subscribe(incidentRootCause -> {
System.out.printf("Description: %s%n", incidentRootCause.getDescription());
System.out.printf("Series Key:");
System.out.println(incidentRootCause.getSeriesKey().asMap());
});
Parameters:
Returns:
listIncidentRootCauses
public PagedFlux
List the root causes for an incident.
Code sample
final String detectionConfigurationId = "c0dddf2539f-b804-4ab9-a70f-0da0c89c76d8";
final String incidentId = "c5thh0f2539f-b804-4ab9-a70f-0da0c89c456d";
metricsAdvisorAsyncClient.listIncidentRootCauses(detectionConfigurationId, incidentId)
.subscribe(incidentRootCause -> {
System.out.printf("Description: %s%n", incidentRootCause.getDescription());
System.out.println("Series Key:");
System.out.println(incidentRootCause.getSeriesKey().asMap());
System.out.printf("Confidence for the detected incident root cause: %.2f%n",
incidentRootCause.getContributionScore());
});
Parameters:
Returns:
listIncidentsForAlert
public PagedFlux
Fetch the incidents in an alert.
Code sample
final String alertConfigurationId = "ff3014a0-bbbb-41ec-a637-677e77b81299";
final String alertId = "1746b031c00";
final ListIncidentsAlertedOptions options = new ListIncidentsAlertedOptions()
.setMaxPageSize(10);
metricsAdvisorAsyncClient.listIncidentsForAlert(
alertConfigurationId,
alertId,
options)
.subscribe(incident -> {
System.out.printf("Data Feed Metric Id: %s%n", incident.getMetricId());
System.out.printf("Detection Configuration Id: %s%n", incident.getDetectionConfigurationId());
System.out.printf("Anomaly Incident Id: %s%n", incident.getId());
System.out.printf("Anomaly Incident Start Time: %s%n", incident.getStartTime());
System.out.printf("Anomaly Incident AnomalySeverity: %s%n", incident.getSeverity());
System.out.printf("Anomaly Incident Status: %s%n", incident.getStatus());
System.out.printf("Root DataFeedDimension Key:");
DimensionKey rootDimension = incident.getRootDimensionKey();
for (Map.Entry<String, String> dimension : rootDimension.asMap().entrySet()) {
System.out.printf("DimensionName: %s DimensionValue:%s%n",
dimension.getKey(), dimension.getValue());
}
});
Parameters:
Returns:
listIncidentsForAlert
public PagedFlux
Fetch the incidents in an alert.
Code sample
final String alertConfigurationId = "ff3014a0-bbbb-41ec-a637-677e77b81299";
final String alertId = "1746b031c00";
final ListIncidentsAlertedOptions options = new ListIncidentsAlertedOptions()
.setMaxPageSize(10);
metricsAdvisorAsyncClient.listIncidentsForAlert(
alertConfigurationId,
alertId,
options)
.subscribe(incident -> {
System.out.printf("Data Feed Metric Id: %s%n", incident.getMetricId());
System.out.printf("Detection Configuration Id: %s%n", incident.getDetectionConfigurationId());
System.out.printf("Anomaly Incident Id: %s%n", incident.getId());
System.out.printf("Anomaly Incident Start Time: %s%n", incident.getStartTime());
System.out.printf("Anomaly Incident AnomalySeverity: %s%n", incident.getSeverity());
System.out.printf("Anomaly Incident Status: %s%n", incident.getStatus());
System.out.printf("Root DataFeedDimension Key:");
DimensionKey rootDimension = incident.getRootDimensionKey();
for (Map.Entry<String, String> dimension : rootDimension.asMap().entrySet()) {
System.out.printf("DimensionName: %s DimensionValue:%s%n",
dimension.getKey(), dimension.getValue());
}
});
Parameters:
Returns:
listIncidentsForDetectionConfig
public PagedFlux
Fetch the incidents identified by an anomaly detection configuration.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T12:00:00Z");
PagedFlux<AnomalyIncident> incidentsFlux
= metricsAdvisorAsyncClient.listIncidentsForDetectionConfig(detectionConfigurationId, startTime,
endTime);
incidentsFlux.subscribe(incident -> {
System.out.printf("Data Feed Metric Id: %s%n", incident.getMetricId());
System.out.printf("Detection Configuration Id: %s%n", incident.getDetectionConfigurationId());
System.out.printf("Anomaly Incident Id: %s%n", incident.getId());
System.out.printf("Anomaly Incident Start Time: %s%n", incident.getStartTime());
System.out.printf("Anomaly Incident AnomalySeverity: %s%n", incident.getSeverity());
System.out.printf("Anomaly Incident Status: %s%n", incident.getStatus());
System.out.printf("Root DataFeedDimension Key: %s%n", incident.getRootDimensionKey().asMap());
});
Parameters:
Returns:
listIncidentsForDetectionConfig
public PagedFlux
Fetch the incidents identified by an anomaly detection configuration.
Code sample
final String detectionConfigurationId = "c0f2539f-b804-4ab9-a70f-0da0c89c76d8";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T12:00:00Z");
final ListIncidentsDetectedOptions options = new ListIncidentsDetectedOptions()
.setMaxPageSize(1000);
PagedFlux<AnomalyIncident> incidentsFlux
= metricsAdvisorAsyncClient.listIncidentsForDetectionConfig(detectionConfigurationId, startTime,
endTime, options);
incidentsFlux.subscribe(incident -> {
System.out.printf("Data Feed Metric Id: %s%n", incident.getMetricId());
System.out.printf("Detection Configuration Id: %s%n", incident.getDetectionConfigurationId());
System.out.printf("Anomaly Incident Id: %s%n", incident.getId());
System.out.printf("Anomaly Incident Start Time: %s%n", incident.getStartTime());
System.out.printf("Anomaly Incident AnomalySeverity: %s%n", incident.getSeverity());
System.out.printf("Anomaly Incident Status: %s%n", incident.getStatus());
System.out.printf("Root DataFeedDimension Key: %s%n", incident.getRootDimensionKey().asMap());
});
Parameters:
Returns:
listMetricDimensionValues
public PagedFlux
List dimension values from certain metric.
Code sample
metricsAdvisorAsyncClient.listMetricDimensionValues("metricId", "dimension1")
.subscribe(System.out::println);
Parameters:
Returns:
listMetricDimensionValues
public PagedFlux
List dimension values from certain metric.
Code sample
metricsAdvisorAsyncClient.listMetricDimensionValues("metricId", "dimension1",
new ListMetricDimensionValuesOptions().setDimensionValueToFilter("value1").setMaxPageSize(3))
.subscribe(System.out::println);
Parameters:
Returns:
listMetricEnrichedSeriesData
public PagedFlux
Given a list of time series keys, retrieve time series version enriched using a detection configuration.
Code sample
final String detectionConfigurationId = "e87d899d-a5a0-4259-b752-11aea34d5e34";
final DimensionKey seriesKey = new DimensionKey()
.put("Dim1", "Common Lime")
.put("Dim2", "Antelope");
final OffsetDateTime startTime = OffsetDateTime.parse("2020-08-12T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-12T00:00:00Z");
PagedFlux<MetricEnrichedSeriesData> enrichedDataFlux
= metricsAdvisorAsyncClient.listMetricEnrichedSeriesData(detectionConfigurationId,
Arrays.asList(seriesKey),
startTime,
endTime);
enrichedDataFlux.subscribe(enrichedData -> {
System.out.printf("Series Key %s%n:", enrichedData.getSeriesKey().asMap());
System.out.println("List of data points for this series");
System.out.println(enrichedData.getMetricValues());
System.out.println("Timestamps of the data related to this time series:");
System.out.println(enrichedData.getTimestamps());
System.out.println("The expected values of the data points calculated by the smart detector:");
System.out.println(enrichedData.getExpectedMetricValues());
System.out.println("The lower boundary values of the data points calculated by smart detector:");
System.out.println(enrichedData.getLowerBoundaryValues());
System.out.println("the periods calculated for the data points in the time series:");
System.out.println(enrichedData.getPeriods());
});
Parameters:
seriesKeys
.
Returns:
listMetricEnrichmentStatus
public PagedFlux
List the enrichment status for a metric.
Code sample
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final String metricId = "d3gh4i4-b804-4ab9-a70f-0da0c89cft3l";
metricsAdvisorAsyncClient.listMetricEnrichmentStatus(metricId, startTime, endTime)
.subscribe(enrichmentStatus -> {
System.out.printf("Data Feed Metric enrichment status : %s%n", enrichmentStatus.getStatus());
System.out.printf("Data Feed Metric enrichment status message: %s%n", enrichmentStatus.getMessage());
System.out.printf("Data Feed Metric enrichment status data slice timestamp : %s%n",
enrichmentStatus.getTimestamp());
});
Parameters:
Returns:
listMetricEnrichmentStatus
public PagedFlux
List the enrichment status for a metric.
Code sample
final OffsetDateTime startTime = OffsetDateTime.parse("2020-01-01T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final String metricId = "d3gh4i4-b804-4ab9-a70f-0da0c89cft3l";
final ListMetricEnrichmentStatusOptions options = new ListMetricEnrichmentStatusOptions().setMaxPageSize(10);
metricsAdvisorAsyncClient.listMetricEnrichmentStatus(metricId, startTime, endTime, options)
.subscribe(enrichmentStatus -> {
System.out.printf("Data Feed Metric enrichment status : %s%n", enrichmentStatus.getStatus());
System.out.printf("Data Feed Metric enrichment status message: %s%n", enrichmentStatus.getMessage());
System.out.printf("Data Feed Metric enrichment status data slice timestamp : %s%n",
enrichmentStatus.getTimestamp());
});
Parameters:
Returns:
listMetricSeriesData
public PagedFlux
Get time series data from metric.
Code sample
final String metricId = "2dgfbbbb-41ec-a637-677e77b81455";
final OffsetDateTime startTime = OffsetDateTime.parse("2020-09-09T00:00:00Z");
final OffsetDateTime endTime = OffsetDateTime.parse("2020-09-09T12:00:00Z");
final List<DimensionKey> seriesKeyFilter
= Arrays.asList(new DimensionKey().put("cost", "redmond"));
metricsAdvisorAsyncClient.listMetricSeriesData(metricId, seriesKeyFilter, startTime, endTime)
.subscribe(metricSeriesData -> {
System.out.println("List of data points for this series:");
System.out.println(metricSeriesData.getMetricValues());
System.out.println("Timestamps of the data related to this time series:");
System.out.println(metricSeriesData.getTimestamps());
System.out.printf("Series Key:");
System.out.println(metricSeriesData.getSeriesKey().asMap());
});
Parameters:
Returns:
listMetricSeriesDefinitions
public PagedFlux
List series definition for a metric.
Code sample
String metricId = "b460abfc-7a58-47d7-9d99-21ee21fdfc6e";
final OffsetDateTime activeSince = OffsetDateTime.parse("2020-07-10T00:00:00Z");
metricsAdvisorAsyncClient.listMetricSeriesDefinitions(metricId, activeSince)
.subscribe(metricSeriesDefinition -> {
System.out.printf("Data Feed Metric id for the retrieved series definition : %s%n",
metricSeriesDefinition.getMetricId());
System.out.printf("Series Key:");
System.out.println(metricSeriesDefinition.getSeriesKey().asMap());
});
Parameters:
Returns:
listMetricSeriesDefinitions
public PagedFlux
List series definition for a metric.
Code sample
String metricId = "b460abfc-7a58-47d7-9d99-21ee21fdfc6e";
final OffsetDateTime activeSince = OffsetDateTime.parse("2020-07-10T00:00:00Z");
final ListMetricSeriesDefinitionOptions options
= new ListMetricSeriesDefinitionOptions()
.setMaxPageSize(10)
.setDimensionCombinationToFilter(new HashMap<String, List<String>>() {{
put("Dim2", Collections.singletonList("Angelfish"));
}});
metricsAdvisorAsyncClient.listMetricSeriesDefinitions(metricId, activeSince, options)
.subscribe(metricSeriesDefinition -> {
System.out.printf("Data Feed Metric id for the retrieved series definition : %s%n",
metricSeriesDefinition.getMetricId());
System.out.printf("Series Key:");
System.out.println(metricSeriesDefinition.getSeriesKey().asMap());
});
Parameters:
Returns:
Applies to
Azure SDK for Java