DEV Community

Cover image for Monitoring AWS Lambda Functions with AWS X-Ray and CloudWatch: Advanced Technique
Kevin Kiruri for AWS Community Builders

Posted on

Monitoring AWS Lambda Functions with AWS X-Ray and CloudWatch: Advanced Technique

It is essential to understand the state of your Lambda-based application to ensure its reliability and health. Monitoring provides information that helps you detect and resolve performance problems, outages and errors in your workloads. Lambda-based applications often integrate with multiple services, which makes it just as important that you monitor each service endpoint. In this article, we will explore advanced techniques that allow you to leverage AWS X-Ray and CloudWatch to monitor and observe your applications.

AWS X-Ray Advanced features with Lambda:

Since most serverless applications consist of multiple service integrations, troubleshooting performance issues or errors usually involves tracking a request from the source caller through all involved services. In this case, AWS X-Ray is a faster and more convenient tool to trace distributed capabilities as it allows you to visualise and analyse the flow of requests across your application.

To use X-Ray in Lambda you can activate it in the Lambda console for a specific function or enable it in the AWS SAM template:

Resources:
  GetLocations:
    Type: AWS::Serverless::Function
    Properties:
      Tracing: Active


Enter fullscreen mode Exit fullscreen mode

Make sure you also provide permission using the AWSXRayDaemonWriteAccess managed policy. You must also activate X-Ray for each service in your workload. Once enabled X-Ray starts collecting tracing data for events. You can instrument your code using AWS X-Ray SDK to annotate traces and add custom metadata. In python:

from aws_xray_sdk.core import xray_recorder

@xray_recorder.capture('process_event')
def lambda_handler(event, context):
    # Your function logic here
    pass
Enter fullscreen mode Exit fullscreen mode

You can isolate which part of the system is causing the most latency using the X-Ray service map, which visually represents the communication between your lambda function and other services on the X-Ray console.

Finally, using Subsegments, leverage granular tracing within a single Lambda invocation. In python:

with xray_recorder.in_segment('custom_subsegment'):
    # Specific operations to trace
    pass
Enter fullscreen mode Exit fullscreen mode

AWS CloudWatch

AWS CloudWatch provides a platform for centralised monitoring and logging. All Lambda functions are automatically integrated with CloudWatch and log various standard metrics that get published to CloudWatch metrics. Key CloudWatch metrics for lambda include invocations, Errors, Duration, Concurrent executions and memory usage. You can create CloudWatch alarms based on these metrics to alert on threshold. Leverage the creation of custom Dashboards to display key metrics such as errors, execution duration, and invocations in one view. Analyze Logs using CloudWatch Logs Insights to query your application’s logs for debugging and optimization.

Advanced Monitoring with X-Ray and CloudWatch

  • Correlate Traces and Logs: Use trace IDs to link X-Ray traces with CloudWatch logs for detailed debugging. This enables you to trace a request’s journey and investigate logs for specific trace segments, offering precise context during troubleshooting.

  • Real-time Anomaly Detection: Enable anomaly detection in CloudWatch to establish dynamic thresholds based on historical patterns. This helps automatically identify unusual behaviours in your metrics, such as unexpected spikes in errors or latency, reducing the manual effort in monitoring setups.

  • Automating Alerting and Remediation: Set up CloudWatch alarms based on Lambda performance or error trends and automate remediation steps using SNS or step functions to handle issues as soon as they arise

  • Optimise Performance: Regularly analyze X-Ray traces and CloudWatch metrics to identify inefficiencies, such as redundant function calls or underutilized resources. These insights allow you to fine-tune function configurations, optimize code, and reduce operational costs.

Monitoring Lambda-based applications with AWS X-Ray and CloudWatch enables you to maintain high availability, optimize performance, and quickly resolve issues. By focusing on critical metrics like errors, execution time, and throttling, and leveraging the advanced capabilities of these tools, you can build robust and resilient serverless applications.

Happy Monitoring!
Let's connect on LinkedIn

Top comments (2)

Collapse
 
navapon profile image
Navapon

May I ask if we have an active x-ray for the lambda.

If we don't add a span to our code, the result will not show detailed function tracing, right?

Collapse
 
kevin_k profile image
Kevin Kiruri

Right. Without adding spans or subsegments, X-Ray only captures high-level information like Lambda invocation, execution time, and AWS SDK service calls. To enable detailed tracing and pinpoint specific operations causing latency or errors within your function, you need to add spans. While enabling X-Ray is a great start, spans provide the detailed visibility you need