I have an Amazon Relational Database Service (Amazon RDS) DB instance that runs SQL Server. I want to create Amazon CloudWatch alarms and Amazon Simple Notification Service (Amazon SNS) topics so that I'm notified about specific events. For example, SQL Server error and agent log events that match CloudWatch filter patterns.
Short description
First, publish SQL Server logs to Amazon CloudWatch Logs. Then, create CloudWatch alarms and SNS notifications for the SQL Server DB log events that match the filter pattern that you create.
After the Amazon RDS for SQL Server log data is published to CloudWatch, you can create metric filters to search and filter the logs. Metric filters define the terms and patterns that are searched for in the log data as it is sent to Amazon CloudWatch Logs. Then, CloudWatch Logs uses the metric filters to turn log data into numerical CloudWatch metrics that you can set alarms for.
You can use any type of CloudWatch statistic, such as percentile statistics when you view these metrics or set alarms. For more information, see Creating metrics from log events using filters.
Resolution
You can create filter patterns, such as "Login failed for user" to identify failed login attempts. Or, you can create a filter for "I/O requests taking longer than 15 seconds to complete" to identify I/O bottlenecks or disk bottlenecks.
The following example uses a filter to search for and count events that include the term "Login failed for user" to track failed login attempts.
Note: By default, Amazon RDS DB logs aren't published to CloudWatch Logs. To get started, follow the steps to publish SQL Server logs to Amazon CloudWatch Logs.
- Open the Amazon RDS console, and choose Databases from the navigation pane.
- Choose the name of the DB instance that you want to configure CloudWatch metrics for.
- From the Configuration tab, choose Error under CloudWatch Logs. This opens the Logs pane in the CloudWatch console. If you don't see a Published Logs section, be sure that you publish SQL Server logs to CloudWatch Logs.
- From the CloudWatch console navigation pane, choose Log groups.
- Choose the error log for the RDS DB instance, and then choose Create Metric Filter.
- For Filter Pattern, enter a pattern, such as "Login failed for user."
Note: All entries in the filter pattern are case sensitive.
- From the same page, you can test the filter pattern. Select the log group that you want to test the filter against under the Select Log Data to Test section, and then choose Test Pattern.
- From the Results section, you can see how many results match the filter pattern in the log file. You can also choose Show test results to see more details.
- Choose Assign Metric.
- Enter a Filter name and a Metric name.
- Choose Show advanced metric settings, and confirm that Metric Value is set to 1. This value specifies that the count is incremented by 1 for each log event that contains "Login Failed for User."
- For Default Value, enter 0.
- Choose Create Filter. A Create Alarm button displays. Choose Create Alarm.
- From the Period dropdown list, select the evaluation period. The default period is 5 minutes.
- From the Conditions section, choose the following:
Threshold type - Static.
Whenever test is - Greater > threshold.
Than - Enter 10.
- Expand the Additional configuration section. For Datapoints to alarm, enter the number of evaluation periods (data points) that must be in the ALARM state to trigger the alarm.
- From Missing data treatment, select Treat missing data as missing.
- Choose Next.
- From the Notification section, under Select an SNS topic, select an existing SNS topic, or create a new topic to receive notifications.
- Enter the email endpoints that you want to receive the notification.
- Choose Next.
- Enter the Alarm name and Alarm description, and then choose Next.
- From the Preview and create page, review the Metric graph and Conditions.
- Choose Create alarm.
After following these example steps, the alarm state is Insufficient data for the first few minutes. After the alarm has enough data, the status is OK. If you receive more than 10 login failures within a 5-minute period, then the CloudWatch alarm sends an SNS notification to the email specified.
Related information
Overview of monitoring metrics in Amazon RDS