Amazon CloudWatch Lambda Insights collects and aggregates Lambda function runtime performance metrics and logs for your serverless applications.
Topics
- How Lambda Insights monitors serverless applications
- Pricing
- Supported runtimes
- Region availability
- Enabling Lambda Insights in the Lambda console
- Enabling Lambda Insights programmatically
- Using the Lambda Insights dashboard
- Example workflow to detect function anomalies
- Example workflow using queries to troubleshoot a function
CloudWatch Lambda Insights is a monitoring and troubleshooting solution for serverless applications running on AWS Lambda. The solution collects, aggregates, and summarizes system-level metrics including CPU time, memory, disk and network usage. It also collects, aggregates, and summarizes diagnostic information such as cold starts and Lambda worker shutdowns to help you isolate issues with your Lambda functions and resolve them quickly.
Lambda Insights uses a new CloudWatch Lambda Insights extension, which is provided as a Lambda layer. When you enable this extension on a Lambda function for a supported runtime, it collects system-level metrics and emits a single performance log event for every invocation of that Lambda function. CloudWatch uses embedded metric formatting to extract metrics from the log events. For more information, see Using AWS Lambda extensions.
The Lambda Insights layer extends the CreateLogStream
and PutLogEvents
for the /aws/lambda-insights/
log group.
For each Lambda function enabled for Lambda Insights, you only pay for what you use for metrics and logs. For a pricing example, see Amazon CloudWatch pricing.
You can use Lambda Insights with any of the following Lambda function runtimes:
- .NET Core 3.1 (C#/PowerShell) (
dotnetcore3.1
) - Custom runtime (
provided
) - Custom runtime on Amazon Linux 2 (
provided.al2
) - Java 11 (Corretto) (
java11
) - Java 8 (Corretto) (
java8.al2
) - Node.js 12.x (
nodejs12.x
) - Node.js 10.x (
nodejs10.x
) - Python 3.8 (
python3.8
) - Python 3.7 (
python3.7
) - Ruby 2.7 (
ruby2.7
) - Ruby 2.5 (
ruby2.5
)
Lambda Insights is currently available in the following AWS Regions:
- US East (N. Virginia)
- US East (Ohio)
- US West (N. California)
- US West (Oregon)
- Asia Pacific (Mumbai)
- Asia Pacific (Seoul)
- Asia Pacific (Singapore)
- Asia Pacific (Sydney)
- Asia Pacific (Tokyo)
- Canada (Central)
- Europe (Frankfurt)
- Europe (Ireland)
- Europe (London)
- Europe (Paris)
- Europe (Stockholm)
- South America (São Paulo)
You can enable Lambda Insights enhanced monitoring on new and existing Lambda functions. When you enable Lambda Insights on a function in the Lambda console for a supported runtime, Lambda adds the Lambda Insights extension as a layer to your function, and verifies or attempts to attach the https://console.aws.amazon.com/iam/home#/policies/arn:aws:iam::aws:policy/CloudWatchLambdaInsightsExecutionRolePolicy$jsonEditor policy to your function’s execution role.
To enable Lambda Insights in the Lambda console
-
Open the Functions page on the Lambda console.
-
Choose your function.
-
Choose the Configuration tab.
-
On the Monitoring tools pane, choose Edit.
-
Under Lambda Insights, turn on Enhanced monitoring.
-
Choose Save.
You can also enable Lambda Insights using the AWS Command Line Interface (AWS CLI), AWS Serverless Application Model (SAM) CLI, AWS CloudFormation, or the AWS Cloud Development Kit (AWS CDK). When you enable Lambda Insights programmatically on a function for a supported runtime, CloudWatch attaches the https://console.aws.amazon.com/iam/home#/policies/arn:aws:iam::aws:policy/CloudWatchLambdaInsightsExecutionRolePolicy$jsonEditor policy to your function’s execution role.
For more information, see Getting started with Lambda Insights in the Amazon CloudWatch User Guide.
The Lambda Insights dashboard has two views in the CloudWatch console: the multi-function overview and the single-function view. The multi-function overview aggregates the runtime metrics for the Lambda functions in the current AWS account and Region. The single-function view shows the available runtime metrics for a single Lambda function.
You can use the Lambda Insights dashboard multi-function overview in the CloudWatch console to identify over- and under-utilized Lambda functions. You can use the Lambda Insights dashboard single-function view in the CloudWatch console to troubleshoot individual requests.
To view the runtime metrics for all functions
-
Open the Multi-function page in the CloudWatch console.
-
Choose from the predefined time ranges, or choose a custom time range.
-
(Optional) Choose Add to dashboard to add the widgets to your CloudWatch dashboard.
To view the runtime metrics of a single function
-
Open the Single-function page in the CloudWatch console.
-
Choose from the predefined time ranges, or choose a custom time range.
-
(Optional) Choose Add to dashboard to add the widgets to your CloudWatch dashboard.
For more information, see Creating and working with widgets on CloudWatch dashboards.
You can use the multi-function overview on the Lambda Insights dashboard to identify and detect compute memory anomalies with your function. For example, if the multi-function overview indicates that a function is using a large amount of memory, you can view detailed memory utilization metrics in the Memory Usage pane. You can then go to the Metrics dashboard to enable anomaly detection or create an alarm.
To enable anomaly detection for a function
-
Open the Multi-function page in the CloudWatch console.
-
Under Function summary, choose your function's name.
The single-function view opens with the function runtime metrics.
-
On the Memory Usage pane, choose the three vertical dots, and then choose View in metrics to open the Metrics dashboard.
-
On the Graphed metrics tab, in the Actions column, choose the first icon to enable anomaly detection for the function.
For more information, see Using CloudWatch Anomaly Detection.
You can use the single-function view on the Lambda Insights dashboard to identify the root cause of a spike in function duration. For example, if the multi-function overview indicates a large increase in function duration, you can pause on or choose each function in the Duration pane to determine which function is causing the increase. You can then go to the single-function view and review the Application logs to determine the root cause.
To run queries on a function
-
Open the Multi-function page in the CloudWatch console.
-
In the Duration pane, choose your function to filter the duration metrics.
-
Open the Single-function page.
-
Choose the Filter metrics by function name dropdown list, and then choose your function.
-
To view the Most recent 1000 application logs, choose the Application logs tab.
-
Review the Timestamp and Message to identify the invocation request that you want to troubleshoot.
-
To show the Most recent 1000 invocations, choose the Invocations tab.
-
Select the Timestamp or Message for the invocation request that you want to troubleshoot.
-
Choose the View logs dropdown list, and then choose View performance logs.
An autogenerated query for your function opens in the Logs Insights dashboard.
-
Choose Run query to generate a Logs message for the invocation request.