PutAlarmMuteRule
Creates or updates an alarm mute rule.
Alarm mute rules automatically mute alarm actions during predefined time windows. When a mute rule is active, targeted alarms continue to evaluate metrics and transition between states, but their configured actions (such as Amazon SNS notifications or Auto Scaling actions) are muted.
You can create mute rules with recurring schedules using cron expressions or one-time mute windows using at expressions. Each mute rule can target up to 100 specific alarms by name.
If you specify a rule name that already exists, this operation updates the existing rule with the new configuration.
Permissions
To create or update a mute rule, you must have the cloudwatch:PutAlarmMuteRule permission on two types of resources: the alarm mute rule resource itself, and each alarm that the rule targets.
For example, If you want to allow a user to create mute rules that target only specific alarms named "WebServerCPUAlarm" and "DatabaseConnectionAlarm", you would create an IAM policy with one statement granting cloudwatch:PutAlarmMuteRule on the alarm mute rule resource (arn:aws:cloudwatch:[REGION]:123456789012:alarm-mute-rule:*), and another statement granting cloudwatch:PutAlarmMuteRule on the targeted alarm resources (arn:aws:cloudwatch:[REGION]:123456789012:alarm:WebServerCPUAlarm and arn:aws:cloudwatch:[REGION]:123456789012:alarm:DatabaseConnectionAlarm).
You can also use IAM policy conditions to allow targeting alarms based on resource tags. For example, you can restrict users to create/update mute rules to only target alarms that have a specific tag key-value pair, such as Team=TeamA.
Request Parameters
- Description
-
A description of the alarm mute rule that helps you identify its purpose.
Type: String
Length Constraints: Minimum length of 0. Maximum length of 1024.
Required: No
- ExpireDate
-
The date and time when the mute rule expires and is no longer evaluated. After this time, the rule status becomes EXPIRED and will no longer mute the targeted alarms. This date and time is interpreted according to the schedule timezone, or UTC if no timezone is specified.
Type: Timestamp
Required: No
- MuteTargets
-
Specifies which alarms this rule applies to.
Type: MuteTargets object
Required: No
- Name
-
The name of the alarm mute rule. This name must be unique within your AWS account and region.
Type: String
Length Constraints: Minimum length of 1. Maximum length of 255.
Required: Yes
- Rule
-
The configuration that defines when and how long alarms should be muted.
Type: Rule object
Required: Yes
- StartDate
-
The date and time after which the mute rule takes effect. If not specified, the mute rule takes effect immediately upon creation and the mutes are applied as per the schedule expression. This date and time is interpreted according to the schedule timezone, or UTC if no timezone is specified.
Type: Timestamp
Required: No
- Tags
-
A list of key-value pairs to associate with the alarm mute rule. You can use tags to categorize and manage your mute rules.
Type: Array of Tag objects
Required: No
Errors
For information about the errors that are common to all actions, see Common Errors.
- LimitExceeded
-
The quota for alarms for this customer has already been reached.
- message
HTTP Status Code: 400
Examples
Create a recurring daily mute rule
Create a mute rule that mutes specific alarms every day from 2:00 AM to 4:00 AM UTC.
Sample Request
aws cloudwatch put-alarm-mute-rule \
--name "DailyMaintenanceWindow" \
--description "Mute alarms during daily maintenance" \
--rule '{
"Schedule": {
"Expression": "cron(0 2 * * ?)",
"Duration": "PT2H",
"Timezone": "UTC"
}
}' \
--mute-targets '{
"AlarmNames": ["WebServerCPUAlarm", "DatabaseConnectionAlarm"]
}'
Create a one-time mute rule
Create a mute rule for a one-time deployment window.
Sample Request
aws cloudwatch put-alarm-mute-rule \
--name "ProductionDeployment-2026-01-20" \
--description "Mute alarms during production deployment" \
--rule '{
"Schedule": {
"Expression": "at(2026-01-20T14:00)",
"Duration": "PT1H",
"Timezone": "America/New_York"
}
}' \
--mute-targets '{
"AlarmNames": ["APILatencyAlarm", "ErrorRateAlarm"]
}'
Create a weekly mute rule with tags
Create a mute rule that mutes specific alarms every Saturday for 4 hours.
Sample Request
aws cloudwatch put-alarm-mute-rule \
--name "WeeklyBackupWindow" \
--description "Mute alarms during weekly backup" \
--rule '{
"Schedule": {
"Expression": "cron(0 0 ? * SAT)",
"Duration": "PT4H",
"Timezone": "America/Los_Angeles"
}
}' \
--mute-targets '{
"AlarmNames": ["BackupAlarm", "StorageAlarm"]
}' \
--tags '[
{"Key": "Environment", "Value": "Production"},
{"Key": "Team", "Value": "Operations"}
]'
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: