From 209ade7f8f2022ec00fc76f67966db3e03bd0e5c Mon Sep 17 00:00:00 2001 From: Lauri Tulmin Date: Wed, 6 Nov 2024 21:14:21 +0200 Subject: [PATCH] Unify aws lambda flush handling (#12576) Co-authored-by: Trask Stalnaker --- .../aws-lambda-core-1.0/javaagent/README.md | 5 +++ .../v1_0/AwsLambdaInstrumentationHelper.java | 13 ++++++++ ...wsLambdaRequestHandlerInstrumentation.java | 3 +- .../aws-lambda-core-1.0/library/README.md | 2 +- .../aws-lambda-events-2.2/javaagent/README.md | 5 +++ .../v2_2/AwsLambdaInstrumentationHelper.java | 33 ++++++++++++------- ...wsLambdaRequestHandlerInstrumentation.java | 3 +- .../aws-lambda-events-2.2/library/README.md | 2 +- .../bootstrap/OpenTelemetrySdkAccess.java | 10 ++++-- 9 files changed, 58 insertions(+), 18 deletions(-) create mode 100644 instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/README.md create mode 100644 instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/README.md diff --git a/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/README.md b/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/README.md new file mode 100644 index 000000000000..94f6359eaf28 --- /dev/null +++ b/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/README.md @@ -0,0 +1,5 @@ +# Settings for the AWS Lambda Instrumentation + +| System property | Type | Default | Description | +|-------------------------------------------------|---------|---------|--------------------------------| +| `otel.instrumentation.aws-lambda.flush-timeout` | Integer | 10000 | Flush timeout in milliseconds. | diff --git a/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaInstrumentationHelper.java b/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaInstrumentationHelper.java index 48a828463707..bc37e29f6bc8 100644 --- a/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaInstrumentationHelper.java +++ b/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaInstrumentationHelper.java @@ -8,15 +8,28 @@ import io.opentelemetry.api.GlobalOpenTelemetry; import io.opentelemetry.instrumentation.awslambdacore.v1_0.internal.AwsLambdaFunctionInstrumenter; import io.opentelemetry.instrumentation.awslambdacore.v1_0.internal.AwsLambdaFunctionInstrumenterFactory; +import io.opentelemetry.instrumentation.awslambdacore.v1_0.internal.WrapperConfiguration; +import io.opentelemetry.javaagent.bootstrap.internal.AgentInstrumentationConfig; +import java.time.Duration; public final class AwsLambdaInstrumentationHelper { private static final AwsLambdaFunctionInstrumenter FUNCTION_INSTRUMENTER = AwsLambdaFunctionInstrumenterFactory.createInstrumenter(GlobalOpenTelemetry.get()); + private static final Duration FLUSH_TIMEOUT = + Duration.ofMillis( + AgentInstrumentationConfig.get() + .getLong( + "otel.instrumentation.aws-lambda.flush-timeout", + WrapperConfiguration.OTEL_LAMBDA_FLUSH_TIMEOUT_DEFAULT.toMillis())); public static AwsLambdaFunctionInstrumenter functionInstrumenter() { return FUNCTION_INSTRUMENTER; } + public static Duration flushTimeout() { + return FLUSH_TIMEOUT; + } + private AwsLambdaInstrumentationHelper() {} } diff --git a/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaRequestHandlerInstrumentation.java b/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaRequestHandlerInstrumentation.java index dfc70b368fc4..93071e04d25e 100644 --- a/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaRequestHandlerInstrumentation.java +++ b/instrumentation/aws-lambda/aws-lambda-core-1.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdacore/v1_0/AwsLambdaRequestHandlerInstrumentation.java @@ -7,6 +7,7 @@ import static io.opentelemetry.javaagent.extension.matcher.AgentElementMatchers.hasClassesNamed; import static io.opentelemetry.javaagent.extension.matcher.AgentElementMatchers.implementsInterface; +import static io.opentelemetry.javaagent.instrumentation.awslambdacore.v1_0.AwsLambdaInstrumentationHelper.flushTimeout; import static io.opentelemetry.javaagent.instrumentation.awslambdacore.v1_0.AwsLambdaInstrumentationHelper.functionInstrumenter; import static net.bytebuddy.matcher.ElementMatchers.isMethod; import static net.bytebuddy.matcher.ElementMatchers.isPublic; @@ -90,7 +91,7 @@ public static void stopSpan( functionInstrumenter().end(functionContext, input, null, throwable); } - OpenTelemetrySdkAccess.forceFlush(1, TimeUnit.SECONDS); + OpenTelemetrySdkAccess.forceFlush(flushTimeout().toNanos(), TimeUnit.NANOSECONDS); } } } diff --git a/instrumentation/aws-lambda/aws-lambda-core-1.0/library/README.md b/instrumentation/aws-lambda/aws-lambda-core-1.0/library/README.md index 932bb41978ea..0af6179dd320 100644 --- a/instrumentation/aws-lambda/aws-lambda-core-1.0/library/README.md +++ b/instrumentation/aws-lambda/aws-lambda-core-1.0/library/README.md @@ -7,7 +7,7 @@ This package contains libraries to help instrument AWS lambda functions in your To use the instrumentation, configure `OTEL_INSTRUMENTATION_AWS_LAMBDA_HANDLER` env property to your lambda handler method in following format `package.ClassName::methodName` and use one of wrappers as your lambda `Handler`. -In order to configure a span flush timeout (default is set to 1 second), please configure `OTEL_INSTRUMENTATION_AWS_LAMBDA_FLUSH_TIMEOUT` env property. The value is in seconds. +In order to configure a span flush timeout (default is set to 10 seconds), please configure `OTEL_INSTRUMENTATION_AWS_LAMBDA_FLUSH_TIMEOUT` env property. The value is in milliseconds. Available wrappers: diff --git a/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/README.md b/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/README.md new file mode 100644 index 000000000000..94f6359eaf28 --- /dev/null +++ b/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/README.md @@ -0,0 +1,5 @@ +# Settings for the AWS Lambda Instrumentation + +| System property | Type | Default | Description | +|-------------------------------------------------|---------|---------|--------------------------------| +| `otel.instrumentation.aws-lambda.flush-timeout` | Integer | 10000 | Flush timeout in milliseconds. | diff --git a/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaInstrumentationHelper.java b/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaInstrumentationHelper.java index d55898e75053..bf10ab374ed6 100644 --- a/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaInstrumentationHelper.java +++ b/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaInstrumentationHelper.java @@ -8,30 +8,39 @@ import com.amazonaws.services.lambda.runtime.events.SQSEvent; import io.opentelemetry.api.GlobalOpenTelemetry; import io.opentelemetry.instrumentation.api.instrumenter.Instrumenter; +import io.opentelemetry.instrumentation.awslambdacore.v1_0.internal.AwsLambdaFunctionInstrumenter; +import io.opentelemetry.instrumentation.awslambdacore.v1_0.internal.WrapperConfiguration; import io.opentelemetry.instrumentation.awslambdaevents.v2_2.internal.AwsLambdaEventsInstrumenterFactory; import io.opentelemetry.instrumentation.awslambdaevents.v2_2.internal.AwsLambdaSqsInstrumenterFactory; import io.opentelemetry.javaagent.bootstrap.internal.AgentCommonConfig; +import io.opentelemetry.javaagent.bootstrap.internal.AgentInstrumentationConfig; +import java.time.Duration; public final class AwsLambdaInstrumentationHelper { - private static final io.opentelemetry.instrumentation.awslambdacore.v1_0.internal - .AwsLambdaFunctionInstrumenter - FUNCTION_INSTRUMENTER = - AwsLambdaEventsInstrumenterFactory.createInstrumenter( - GlobalOpenTelemetry.get(), AgentCommonConfig.get().getKnownHttpRequestMethods()); - - public static io.opentelemetry.instrumentation.awslambdacore.v1_0.internal - .AwsLambdaFunctionInstrumenter - functionInstrumenter() { - return FUNCTION_INSTRUMENTER; - } - + private static final AwsLambdaFunctionInstrumenter FUNCTION_INSTRUMENTER = + AwsLambdaEventsInstrumenterFactory.createInstrumenter( + GlobalOpenTelemetry.get(), AgentCommonConfig.get().getKnownHttpRequestMethods()); private static final Instrumenter MESSAGE_TRACER = AwsLambdaSqsInstrumenterFactory.forEvent(GlobalOpenTelemetry.get()); + private static final Duration FLUSH_TIMEOUT = + Duration.ofMillis( + AgentInstrumentationConfig.get() + .getLong( + "otel.instrumentation.aws-lambda.flush-timeout", + WrapperConfiguration.OTEL_LAMBDA_FLUSH_TIMEOUT_DEFAULT.toMillis())); + + public static AwsLambdaFunctionInstrumenter functionInstrumenter() { + return FUNCTION_INSTRUMENTER; + } public static Instrumenter messageInstrumenter() { return MESSAGE_TRACER; } + public static Duration flushTimeout() { + return FLUSH_TIMEOUT; + } + private AwsLambdaInstrumentationHelper() {} } diff --git a/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaRequestHandlerInstrumentation.java b/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaRequestHandlerInstrumentation.java index b8bb2663bfb1..e05925080782 100644 --- a/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaRequestHandlerInstrumentation.java +++ b/instrumentation/aws-lambda/aws-lambda-events-2.2/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/awslambdaevents/v2_2/AwsLambdaRequestHandlerInstrumentation.java @@ -7,6 +7,7 @@ import static io.opentelemetry.javaagent.extension.matcher.AgentElementMatchers.hasClassesNamed; import static io.opentelemetry.javaagent.extension.matcher.AgentElementMatchers.implementsInterface; +import static io.opentelemetry.javaagent.instrumentation.awslambdaevents.v2_2.AwsLambdaInstrumentationHelper.flushTimeout; import static net.bytebuddy.matcher.ElementMatchers.isMethod; import static net.bytebuddy.matcher.ElementMatchers.isPublic; import static net.bytebuddy.matcher.ElementMatchers.named; @@ -114,7 +115,7 @@ public static void stopSpan( .end(functionContext, input, result, throwable); } - OpenTelemetrySdkAccess.forceFlush(1, TimeUnit.SECONDS); + OpenTelemetrySdkAccess.forceFlush(flushTimeout().toNanos(), TimeUnit.NANOSECONDS); } } } diff --git a/instrumentation/aws-lambda/aws-lambda-events-2.2/library/README.md b/instrumentation/aws-lambda/aws-lambda-events-2.2/library/README.md index 10beb9fe7299..0f33c6df923a 100644 --- a/instrumentation/aws-lambda/aws-lambda-events-2.2/library/README.md +++ b/instrumentation/aws-lambda/aws-lambda-events-2.2/library/README.md @@ -7,7 +7,7 @@ This package contains libraries to help instrument AWS lambda functions in your To use the instrumentation, configure `OTEL_INSTRUMENTATION_AWS_LAMBDA_HANDLER` env property to your lambda handler method in following format `package.ClassName::methodName` and use one of wrappers as your lambda `Handler`. -In order to configure a span flush timeout (default is set to 1 second), please configure `OTEL_INSTRUMENTATION_AWS_LAMBDA_FLUSH_TIMEOUT` env property. The value is in seconds. +In order to configure a span flush timeout (default is set to 10 seconds), please configure `OTEL_INSTRUMENTATION_AWS_LAMBDA_FLUSH_TIMEOUT` env property. The value is in milliseconds. Available wrappers: diff --git a/javaagent-bootstrap/src/main/java/io/opentelemetry/javaagent/bootstrap/OpenTelemetrySdkAccess.java b/javaagent-bootstrap/src/main/java/io/opentelemetry/javaagent/bootstrap/OpenTelemetrySdkAccess.java index 2a966b3e665a..1dc7ce6d1cc7 100644 --- a/javaagent-bootstrap/src/main/java/io/opentelemetry/javaagent/bootstrap/OpenTelemetrySdkAccess.java +++ b/javaagent-bootstrap/src/main/java/io/opentelemetry/javaagent/bootstrap/OpenTelemetrySdkAccess.java @@ -22,13 +22,19 @@ public final class OpenTelemetrySdkAccess { */ public interface ForceFlusher { /** Executes force flush. */ - void run(int timeout, TimeUnit unit); + void run(long timeout, TimeUnit unit); } private static volatile ForceFlusher forceFlush; - /** Forces flushing of pending spans. */ + /** Forces flushing of pending telemetry. */ + @Deprecated public static void forceFlush(int timeout, TimeUnit unit) { + forceFlush((long) timeout, unit); + } + + /** Forces flushing of pending telemetry. */ + public static void forceFlush(long timeout, TimeUnit unit) { forceFlush.run(timeout, unit); }