Constructor and Description |
---|
Builder() |
Modifier and Type | Method and Description |
---|---|
Alarm.Builder |
alarmSummary(String alarmSummary)
Customizable alarm summary (
alarmSummary alarm message
parameter). |
Alarm.Builder |
body(String body)
The human-readable content of the delivered alarm notification.
|
Alarm |
build() |
Alarm.Builder |
compartmentId(String compartmentId)
The OCID
of the compartment containing the alarm.
|
Alarm.Builder |
copy(Alarm model) |
Alarm.Builder |
definedTags(Map<String,Map<String,Object>> definedTags)
Usage of predefined tag keys.
|
Alarm.Builder |
destinations(List<String> destinations)
A list of destinations for alarm notifications.
|
Alarm.Builder |
displayName(String displayName)
A user-friendly name for the alarm.
|
Alarm.Builder |
evaluationSlackDuration(String evaluationSlackDuration)
Customizable slack period to wait for metric ingestion before evaluating the alarm.
|
Alarm.Builder |
freeformTags(Map<String,String> freeformTags)
Simple key-value pair that is applied without any predefined name, type or scope.
|
Alarm.Builder |
id(String id)
The OCID
of the alarm.
|
Alarm.Builder |
isEnabled(Boolean isEnabled)
Whether the alarm is enabled.
|
Alarm.Builder |
isNotificationsPerMetricDimensionEnabled(Boolean isNotificationsPerMetricDimensionEnabled)
When set to
true , splits alarm notifications per metric stream. |
Alarm.Builder |
lifecycleState(Alarm.LifecycleState lifecycleState)
The current lifecycle state of the alarm.
|
Alarm.Builder |
messageFormat(Alarm.MessageFormat messageFormat)
The format to use for alarm notifications.
|
Alarm.Builder |
metricCompartmentId(String metricCompartmentId)
The OCID
of the compartment containing the metric being evaluated by the alarm.
|
Alarm.Builder |
metricCompartmentIdInSubtree(Boolean metricCompartmentIdInSubtree)
When true, the alarm evaluates metrics from all compartments and subcompartments.
|
Alarm.Builder |
namespace(String namespace)
The source service or application emitting the metric that is evaluated by the alarm.
|
Alarm.Builder |
notificationTitle(String notificationTitle)
Customizable notification title (
title alarm message
parameter). |
Alarm.Builder |
notificationVersion(String notificationVersion)
The version of the alarm notification to be delivered.
|
Alarm.Builder |
overrides(List<AlarmOverride> overrides)
A set of overrides that control evaluations of the alarm.
|
Alarm.Builder |
pendingDuration(String pendingDuration)
The period of time that the condition defined in the alarm must persist before the alarm
state changes from “OK” to “FIRING”.
|
Alarm.Builder |
query(String query)
The Monitoring Query Language (MQL) expression to evaluate for the alarm.
|
Alarm.Builder |
repeatNotificationDuration(String repeatNotificationDuration)
The frequency for re-submitting alarm notifications, if the alarm keeps firing without
interruption.
|
Alarm.Builder |
resolution(String resolution)
The time between calculated aggregation windows for the alarm.
|
Alarm.Builder |
resourceGroup(String resourceGroup)
Resource group to match for metric data retrieved by the alarm.
|
Alarm.Builder |
ruleName(String ruleName)
Identifier of the alarm’s base values for alarm evaluation, for use when the alarm
contains overrides.
|
Alarm.Builder |
severity(Alarm.Severity severity)
The perceived type of response required when the alarm is in the “FIRING” state.
|
Alarm.Builder |
suppression(Suppression suppression)
The configuration details for suppressing an alarm.
|
Alarm.Builder |
timeCreated(Date timeCreated)
The date and time the alarm was created.
|
Alarm.Builder |
timeUpdated(Date timeUpdated)
The date and time the alarm was last updated.
|
public Alarm.Builder id(String id)
The OCID of the alarm.
id
- the value to setpublic Alarm.Builder displayName(String displayName)
A user-friendly name for the alarm. It does not have to be unique, and it’s changeable.
This value determines the title of each alarm notification.
Example: High CPU Utilization
displayName
- the value to setpublic Alarm.Builder compartmentId(String compartmentId)
The OCID of the compartment containing the alarm.
compartmentId
- the value to setpublic Alarm.Builder metricCompartmentId(String metricCompartmentId)
The OCID of the compartment containing the metric being evaluated by the alarm.
metricCompartmentId
- the value to setpublic Alarm.Builder metricCompartmentIdInSubtree(Boolean metricCompartmentIdInSubtree)
When true, the alarm evaluates metrics from all compartments and subcompartments. The parameter can only be set to true when metricCompartmentId is the tenancy OCID (the tenancy is the root compartment). A true value requires the user to have tenancy-level permissions. If this requirement is not met, then the call is rejected. When false, the alarm evaluates metrics from only the compartment specified in metricCompartmentId. Default is false.
Example: true
metricCompartmentIdInSubtree
- the value to setpublic Alarm.Builder namespace(String namespace)
The source service or application emitting the metric that is evaluated by the alarm.
Example: oci_computeagent
namespace
- the value to setpublic Alarm.Builder resourceGroup(String resourceGroup)
Resource group to match for metric data retrieved by the alarm. A resource group is a custom string that you can match when retrieving custom metrics. Only one resource group can be applied per metric. A valid resourceGroup value starts with an alphabetical character and includes only alphanumeric characters, periods (.), underscores (_), hyphens (-), and dollar signs ($).
Example: frontend-fleet
resourceGroup
- the value to setpublic Alarm.Builder query(String query)
The Monitoring Query Language (MQL) expression to evaluate for the alarm. The Alarms
feature of the Monitoring service interprets results for each returned time series as
Boolean values, where zero represents false and a non-zero value represents true. A true
value means that the trigger rule condition has been met. The query must specify a
metric, statistic, interval, and trigger rule (threshold or absence). Supported values
for interval depend on the specified time range. More interval values are supported for
smaller time ranges. You can optionally specify dimensions and grouping functions. Also,
you can customize the absence detection
period.
Supported grouping functions: grouping()
, groupBy()
. For information
about writing MQL expressions, see Editing the MQL Expression for a
Query.
For details about MQL, see Monitoring Query Language (MQL)
Reference. For
available dimensions, review the metric definition for the supported service. See
Supported
Services.
Example of threshold alarm:
-----
CpuUtilization[1m]{availabilityDomain="cumS:PHX-AD-1"}.groupBy(availabilityDomain).percentile(0.9) > 85
-----
Example of absence alarm:
-----
CpuUtilization[1m]{availabilityDomain="cumS:PHX-AD-1"}.absent()
----- Example of absence alarm with custom absence detection period of 20 hours:
-----
CpuUtilization[1m]{availabilityDomain="cumS:PHX-AD-1"}.absent(20h)
-----
query
- the value to setpublic Alarm.Builder resolution(String resolution)
The time between calculated aggregation windows for the alarm. Supported value: 1m
resolution
- the value to setpublic Alarm.Builder pendingDuration(String pendingDuration)
The period of time that the condition defined in the alarm must persist before the alarm state changes from “OK” to “FIRING”. For example, a value of 5 minutes means that the alarm must persist in breaching the condition for five minutes before the alarm updates its state to “FIRING”.
The duration is specified as a string in ISO 8601 format (PT10M
for ten
minutes or PT1H
for one hour). Minimum: PT1M. Maximum: PT1H. Default: PT1M.
Under the default value of PT1M, the first evaluation that breaches the alarm updates the state to "FIRING".
The alarm updates its status to "OK" when the breaching condition has been clear for the most recent minute.
Example: PT5M
pendingDuration
- the value to setpublic Alarm.Builder severity(Alarm.Severity severity)
The perceived type of response required when the alarm is in the “FIRING” state.
Example: CRITICAL
severity
- the value to setpublic Alarm.Builder body(String body)
The human-readable content of the delivered alarm notification. Optionally include dynamic variables. Oracle recommends providing guidance to operators for resolving the alarm condition. Consider adding links to standard runbook practices. Avoid entering confidential information.
Example: High CPU usage alert. Follow runbook instructions for resolution.
body
- the value to setpublic Alarm.Builder isNotificationsPerMetricDimensionEnabled(Boolean isNotificationsPerMetricDimensionEnabled)
When set to true
, splits alarm notifications per metric stream. When set to
false
, groups alarm notifications across metric streams.
isNotificationsPerMetricDimensionEnabled
- the value to setpublic Alarm.Builder messageFormat(Alarm.MessageFormat messageFormat)
The format to use for alarm notifications. The formats are: * RAW
- Raw JSON
blob. Default value. When the destinations
attribute specifies Streaming
,
all alarm notifications use this format. * PRETTY_JSON
: JSON with new lines and
indents. Available when the destinations
attribute specifies Notifications
only. * ONS_OPTIMIZED
: Simplified, user-friendly layout. Available
when the destinations
attribute specifies Notifications
only. Applies to
Email subscription types only.
messageFormat
- the value to setpublic Alarm.Builder destinations(List<String> destinations)
A list of destinations for alarm notifications. Each destination is represented by the
OCID of a
related resource, such as a NotificationTopic
. Supported destination services:
Notifications, Streaming. Limit: One destination per supported destination service.
destinations
- the value to setpublic Alarm.Builder repeatNotificationDuration(String repeatNotificationDuration)
The frequency for re-submitting alarm notifications, if the alarm keeps firing without
interruption. Format defined by ISO 8601. For example, PT4H
indicates four hours.
Minimum: PT1M. Maximum: P30D.
Default value: null (notifications are not re-submitted).
Example: PT2H
repeatNotificationDuration
- the value to setpublic Alarm.Builder suppression(Suppression suppression)
The configuration details for suppressing an alarm.
suppression
- the value to setpublic Alarm.Builder isEnabled(Boolean isEnabled)
Whether the alarm is enabled.
Example: true
isEnabled
- the value to setpublic Alarm.Builder freeformTags(Map<String,String> freeformTags)
Simple key-value pair that is applied without any predefined name, type or scope. Exists
for cross-compatibility only. Example: {"Department": "Finance"}
freeformTags
- the value to setpublic Alarm.Builder definedTags(Map<String,Map<String,Object>> definedTags)
Usage of predefined tag keys. These predefined keys are scoped to namespaces. Example:
{"Operations": {"CostCenter": "42"}}
definedTags
- the value to setpublic Alarm.Builder overrides(List<AlarmOverride> overrides)
A set of overrides that control evaluations of the alarm.
Each override can specify values for query, severity, body, and pending duration. When
an alarm contains overrides, the Monitoring service evaluates each override in order,
beginning with the first override in the array (index position 0
), and then
evaluates the alarm's base values (ruleName
value of BASE
).
overrides
- the value to setpublic Alarm.Builder ruleName(String ruleName)
Identifier of the alarm’s base values for alarm evaluation, for use when the alarm
contains overrides. Default value is BASE
. For information about alarm overrides,
see alarmOverride
.
ruleName
- the value to setpublic Alarm.Builder notificationVersion(String notificationVersion)
The version of the alarm notification to be delivered. Allowed value: 1.X
The
value must start with a number (up to four digits), followed by a period and an uppercase
X.
notificationVersion
- the value to setpublic Alarm.Builder notificationTitle(String notificationTitle)
Customizable notification title (title
alarm message
parameter).
Optionally include dynamic
variables.
The notification title appears as the subject line in a formatted email message and as
the title in a Slack message.
notificationTitle
- the value to setpublic Alarm.Builder evaluationSlackDuration(String evaluationSlackDuration)
Customizable slack period to wait for metric ingestion before evaluating the alarm.
Specify a string in ISO 8601 format (PT10M
for ten minutes or PT1H
for
one hour). Minimum: PT3M. Maximum: PT2H. Default: PT3M. For more information about the
slack period, see About the Internal Reset
Period.
evaluationSlackDuration
- the value to setpublic Alarm.Builder alarmSummary(String alarmSummary)
Customizable alarm summary (alarmSummary
alarm message
parameter).
Optionally include dynamic
variables.
The alarm summary appears within the body of the alarm message and in responses to listAlarmsStatus
getAlarmHistory
and retrieveDimensionStates
.
alarmSummary
- the value to setpublic Alarm.Builder lifecycleState(Alarm.LifecycleState lifecycleState)
The current lifecycle state of the alarm.
Example: DELETED
lifecycleState
- the value to setpublic Alarm.Builder timeCreated(Date timeCreated)
The date and time the alarm was created. Format defined by RFC3339.
Example: 2023-02-01T01:02:29.600Z
timeCreated
- the value to setpublic Alarm.Builder timeUpdated(Date timeUpdated)
The date and time the alarm was last updated. Format defined by RFC3339.
Example: 2023-02-03T01:02:29.600Z
timeUpdated
- the value to setpublic Alarm build()
public Alarm.Builder copy(Alarm model)
Copyright © 2016–2024. All rights reserved.