SetAlarmState
Temporarily sets the state of an alarm for testing purposes. When the updated state
differs from the previous value, the action configured for the appropriate state is
invoked. For example, if your alarm is configured to send an Amazon SNS message when an
alarm is triggered, temporarily changing the alarm state to ALARM
sends an
SNS message.
Metric alarms returns to their actual state quickly, often within seconds. Because the metric alarm state change happens quickly, it is typically only visible in the alarm's History tab in the Amazon CloudWatch console or through DescribeAlarmHistory.
If you use SetAlarmState
on a composite alarm, the composite alarm is
not guaranteed to return to its actual state. It returns to its actual state only once
any of its children alarms change state. It is also reevaluated if you update its
configuration.
If an alarm triggers EC2 Auto Scaling policies or application Auto Scaling
policies, you must include information in the StateReasonData
parameter to
enable the policy to take the correct action.
Request Parameters
For information about the parameters that are common to all actions, see Common Parameters.
- AlarmName
-
The name of the alarm.
Type: String
Length Constraints: Minimum length of 1. Maximum length of 255.
Required: Yes
- StateReason
-
The reason that this alarm is set to this specific state, in text format.
Type: String
Length Constraints: Minimum length of 0. Maximum length of 1023.
Required: Yes
- StateReasonData
-
The reason that this alarm is set to this specific state, in JSON format.
For SNS or EC2 alarm actions, this is just informational. But for EC2 Auto Scaling or application Auto Scaling alarm actions, the Auto Scaling policy uses the information in this field to take the correct action.
Type: String
Length Constraints: Minimum length of 0. Maximum length of 4000.
Required: No
- StateValue
-
The value of the state.
Type: String
Valid Values:
OK | ALARM | INSUFFICIENT_DATA
Required: Yes
Errors
For information about the errors that are common to all actions, see Common Errors.
- InvalidFormat
-
Data was not syntactically valid JSON.
HTTP Status Code: 400
- ResourceNotFound
-
The named resource does not exist.
HTTP Status Code: 404
Examples
Example
The following example sets the alarm state to ALARM, and provides
information inside of StateReasonData
so that Auto Scaling actions
can be performed correctly according to your Auto Scaling policies.
{ "AlarmName": "ExampleAlarmName", "StateValue": "ALARM", "StateReason": "Testing Alarm State", "StateReasonData": { "Version": "1.0", "QueryDate": "2018-10-31T14:32:52.031+0000", "StartDate": "2018-10-31T14:31:00.000+0000", "Statistic": "Average", "Period": 60, "RecentDatapoints": [ 100 ], "Threshold": 50 } }
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: