Performance impact and overhead
Stack Serverless Observability
As described in APM Architecture for AWS Lambda, using Elastic APM with AWS Lambda requires adding both the Elastic APM AWS Lambda extension and a corresponding Elastic APM agent to the Lambda runtime. These components may introduce a small overhead on the size of your functionโs deployment package as well as the execution duration of your functionโs invocations.
These components contribute a little to the uncompressed deployment package size of your Lambda function. Overall, the impact of using Elastic APM on the uncompressed deployment package size of your Lambda function is less than 30MB.
An advantage of the Elastic APM AWS Lambda extension architecture is that APM data dispatching is decoupled from your functionโs request processing. The Elastic APM AWS Lambda extension flushes APM data to the Elastic backend after your function responds to the clientโs request. Thus, it does not affect the latency of the clientโs request. However, the extensionโs flushing of APM data contributes to the overall execution time of the function invocation. The ELASTIC_APM_DATA_FORWARDER_TIMEOUT
config option with the related exponential backoff algorithm limits and allows to control the impact the extension may have on the functionโs overall execution time.
When your function experiences a cold start, the Elastic APM AWS Lambda extension needs to be initialized and, thus, slightly increases the cold start duration (in the range of tens of milliseconds) of your function.
APM agents enrich your applicationโs code with measurement code that collects APM data. This measurement code introduces a small performance overhead to your application, which is usually in a negligible range. The same is true with Lambda functions. The concrete performance overhead introduced by APM agents highly depends on the configuration of the agent and on the characteristics of your functionโs code. The following agent-specific documentation pages provide insights and instructions on tuning the performance the APM agents:
Similar to the Elastic APM AWS Lambda extension, APM agents are initialized at cold start time. As a consequence, the APM agentโs overhead will be higher for cold starts as compared to their overhead on warm invocations. This effect is especially relevant for the Java APM agent on AWS Lambda. Learn more about corresponding tuning options in the Java Agentโs AWS Lambda documentation.