PutAlarmMuteRule - Amazon CloudWatch

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: