Amazon - CloudWatch Logs Workflow Step Plugins
Amazon - CloudWatch Logs Workflow Step Plugins
AWS CloudWatch can serve as a log-aggregator for the majority of logs generated within your cloud environment. This includes logs from the Cloud infrastructure, such as ELB logs and VPC Flow logs, as well as logs from the applications running on VM's and containers.
With CloudWatch Logs Insights, queries can be made to log groups within CloudWatch to retrieve statistics and visualizations from the logs. You can read more about CloudWatch Logs Insights here
The CloudWatch Logs workflow step plugins allows users to execute queries to your CloudWatch logs as a step within your Automation Job. This can be useful for generating reports as well as automated-debugging and troubleshooting during incidents.
There are two CloudWatch Logs plugins:
AWS / CloudWatch / Logs: Users can insert CloudWatch Logs Insights queries directly into the Runbook Automation Job Step.
AWS / CloudWatch / Execute Saved Query: Users specify a saved Logs Insights query in CloudWatch for Runbook Automation to execute.
Getting Started
Authentication
Follow the instructions outlined in the AWS Plugins Overview for Runbook Automation to authenticate with AWS.
When defining the IAM Role for Runbook Automation, be sure to include the following permissions in the Policy associated with the role:
logs:StartQuery
logs:GetQueryResults
- The Execute Saved Query plugin also requires
logs:DescribeQueryDefinitions
.
Execute Ad-Hoc CloudWatch Logs Query
- When configuring your Automation Job, add the Aws / CloudWatch / Logs Workflow Step.
- In the Query Settings section provide the CloudWatch log group that should be queried using Logs Insights.
- Select a Unit of Time and Past Time Range to filter the Logs Insights query time-range. For example, if you want to query logs from the past day, you would select Days as the Unit of Time and 1 as the Past Time Range:
- Insert the Logs Insights query into the Query String text-box:
Tip
You can insert Job Options into the Query String using ${option.my_job_option}
notation. This allows users or events to provide variable parameters to the query at Job execution time.
See it in Action
This plugin is used in one of the prebuilt Jobs in our Automated Diagnostics Solution. Try out the Solution to see how this plugin can be used as part of incident-response workflows.
Execute Saved CloudWatch Logs Query
- When configuring an Automation Job, add the Aws / CloudWatch / Execute Saved Query Workflow Step.
- Query Path: Provide the folder path where the saved query resides:
- Query Name: Provide the name of the saved query. In the example above,
fetch-nginx
is the name of the saved query. - Log Groups: Provide a list of the CloudWatch Log Groups that the saved query will use as the source of logs. This can be one or multiple Log Groups.
- Unit of Time: Select a unit of time to define the time-range for the CloudWatch Logs query.
- Past Time Range: Define a time-range for the CloudWatch Logs query. For example, if
Minutes
was chosen for Unit of Time, and30
was chosen for Past Time Range, then when the saved query is executed, it will retrieve logs from the past 30 minutes.
Log Queries Output
The output of the CloudWatch Logs queries is presented in a table as shown here: