AWS Cloud Operations Blog
Application Performance Monitoring of AWS Lambda apps with Amazon CloudWatch Application Signals
Amazon CloudWatch Application Signals extends its powerful monitoring and diagnostic capabilities to AWS Lambda. This integration provides Lambda users with streamlined, no-code application performance monitoring, enabling easy access to key metrics such as invocation duration, error rates, cold starts, and throttling events. By bringing together telemetry data across Lambda functions with metrics, traces, and logs, CloudWatch Application Signals offers a unified view of application performance and health. This helps operators quickly identify issues and optimize their Lambda-based applications for responsiveness and reliability.
This storylane demo outlines the CloudWatch Application Signals support for AWS Lambda and guides you through new visualization tools to gain insights on lambda invocations, latencies, fault occurrences, and fault-contributing versions and traces
Key Features
- Unified Dashboard: Get a comprehensive view of Lambda function performance, including latency, errors, and overall health metrics.
- Real-Time Troubleshooting: Dive into correlated traces, metrics, and logs to identify bottlenecks and performance issues.
- Automatic Instrumentation: Leverage OpenTelemetry (OTel) compatibility as CloudWatch Application Signals automatically collects critical Lambda insights without requiring manual code changes.
Monitoring lambda functions
To start monitoring your Lambda functions with CloudWatch Application Signals, simply enable the integration in the CloudWatch console as shown below.
 
 
        Figure 1. Screenshot of Enable CloudWatch Application Signals with option to choose Lambda
After enabling the integration, you can view your lambda function on the Application Signals overview page under the Services section, as shown below.
 
 
        Figure 2. Screenshot of Applications Signals overview page
This will provide details about the service operations and dependencies, including the RED (Requests, Errors, and Duration) charts as shown below.
 
 
        Figure 3. CloudWatch application signals overview page for Lambda function
Click on the Service Operations tab, and it will display the page with monitoring information about Requests and Availability, Latency, Faults and Errors as shown below.
 
 
        Figure 4. Screenshot of Service Operations tab
In the Service operations section, the FunctionHandler operation is shown to be running with a 7.2% fault rate at this time. For analyzing the fault rate, click on any of the peaks in the Faults and Errors chart, and you will be able to see the corresponding spans.
 
 
        Figure 5. Screenshot of spans contributing to faults
Additionally, clicking on Top Contributors will reveal the alias information showing where the faults are originating from. In this case, there is a single prod alias accounting for all 16 faults.
 
 
        Figure 6. Screenshot of top contributors for lambda faults
Clicking the dropdown and choosing the versions option reveals a different story. It appears that the latest version is emitting all the faults, while the earlier version is running well.
 
 
        Figure 7. Different lambda versions contributing faults
To analyze further, click on the span link, which will take you to the Traces page with the trace map, spans timeline, and logs all in one place.
 
 
        Figure 8. Correlated spans for lambda
 
 
        Figure 9. Trace details for the faulty lambda
 
 
        Figure 10. Lambda span timeline
In the spans timeline, clicking on the 5xx fault will show the corresponding exception, as shown below. It appears there is a null pointer exception at lambda_function.py line 27, which is causing all the issues.
 
 
        Figure 11. Segment details with exception information
Conclusion
Amazon CloudWatch Application Signals’ new Lambda support simplifies observability, enabling you to focus on delivering high-quality, responsive applications. As demonstrated above, you can identify the root cause of issues and monitor your Lambda applications with just a few clicks. You can enable CloudWatch Application Signals for applications running on Amazon EKS, Kubernetes, Amazon ECS, Amazon EC2, AWS Lambda, and custom environments (hosted anywhere, including on-premises).
For more information on how to enable Applications Signals for applications running on Amazon EKS, see Enable Application Signals on Amazon EKS clusters.
To enable Applications Signals for applications running on other platforms like Amazon EC2, Amazon ECS, Kubernetes, or Lambda, see Enable Application Signals on Amazon EC2, Amazon ECS, Kubernetes, or Lambda
Reference
