From 881b35f674751d1abb8803ed529fb520f0d15999 Mon Sep 17 00:00:00 2001 From: Stephan Schroevers Date: Mon, 28 Feb 2022 09:45:52 +0100 Subject: [PATCH] Revert "Merge pull request #538 from newrelic/spring-security" This reverts commit 7980165a88a489f198668feca6d8048370dcc66c, reversing changes made to 1f4607e40128486eafea6c5a4058157fea9d317c. See newrelic/newrelic-java-agent#725. --- .../TokenLinkingSubscriber.java | 2 +- instrumentation/netty-reactor-0.8.0/README.md | 36 --------------- .../reactor/netty/TokenLinkingSubscriber.java | 12 ++--- .../core/publisher/Hooks_Instrumentation.java | 6 --- ...antPeriodicWorkerTask_Instrumentation.java | 2 - .../PeriodicWorkerTask_Instrumentation.java | 2 - .../SchedulerTask_Instrumentation.java | 1 - .../scheduler/Schedulers_Instrumentation.java | 45 ------------------- .../scheduler/WorkerTask_Instrumentation.java | 2 - .../HttpTrafficHandler_Instrumentation.java | 8 ---- instrumentation/netty-reactor-0.9.0/README.md | 36 --------------- .../reactor/netty/TokenLinkingSubscriber.java | 12 ++--- .../core/publisher/Hooks_Instrumentation.java | 6 --- ...antPeriodicWorkerTask_Instrumentation.java | 2 - .../PeriodicWorkerTask_Instrumentation.java | 2 - .../SchedulerTask_Instrumentation.java | 1 - .../scheduler/Schedulers_Instrumentation.java | 44 ------------------ .../scheduler/WorkerTask_Instrumentation.java | 2 - .../HttpTrafficHandler_Instrumentation.java | 8 ---- 19 files changed, 7 insertions(+), 222 deletions(-) delete mode 100644 instrumentation/netty-reactor-0.8.0/README.md delete mode 100644 instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java delete mode 100644 instrumentation/netty-reactor-0.9.0/README.md delete mode 100644 instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java diff --git a/instrumentation/netty-reactor-0.7.0/src/main/java/com/nr/instrumentation/TokenLinkingSubscriber.java b/instrumentation/netty-reactor-0.7.0/src/main/java/com/nr/instrumentation/TokenLinkingSubscriber.java index 186e520b35..f103e732a5 100644 --- a/instrumentation/netty-reactor-0.7.0/src/main/java/com/nr/instrumentation/TokenLinkingSubscriber.java +++ b/instrumentation/netty-reactor-0.7.0/src/main/java/com/nr/instrumentation/TokenLinkingSubscriber.java @@ -26,7 +26,7 @@ public class TokenLinkingSubscriber implements CoreSubscriber { public TokenLinkingSubscriber(Subscriber subscriber, Context ctx) { this.subscriber = subscriber; this.context = ctx; - // newrelic-token is added by spring-webflux-5.1 instrumentation of ServerWebExchange + // newrelic-token is added by spring-webflux-5.1 instrumentation this.token = ctx.getOrDefault("newrelic-token", null); } diff --git a/instrumentation/netty-reactor-0.8.0/README.md b/instrumentation/netty-reactor-0.8.0/README.md deleted file mode 100644 index 6e8c9267be..0000000000 --- a/instrumentation/netty-reactor-0.8.0/README.md +++ /dev/null @@ -1,36 +0,0 @@ -# Reactor Netty Instrumentation - -Instrumentation for Reactor Netty server and also some widely used Reactor Core library code. - -This module is largely responsible for instrumenting the Reactor Core library to facilitate the passing, retrieval, -and linking of `Tokens` across contexts to tie asynchronous threads together for individual `Transactions`. - -This instrumentation is dependent on other instrumentation modules to start a `Transaction`. -Typically, the `netty-n.n` modules work with this instrumentation and will start a `Transaction` (see `NettyDispatcher#channelRead`). - -Most commonly this instrumentation comes into play with SpringBoot usage, in which case the `spring` and `spring-webflux` -instrumentation modules also apply and should result in `Transactions` being renamed after the Spring controller. - -## Key Components - -* `TokenLinkingSubscriber` - Implementation of a `reactor.core.CoreSubscriber` (a `Context` aware subscriber) that can be added as - a lifecycle hook on `Flux`/`Mono` operators to propagate, retrieve, and link `Tokens` across async contexts. This is done in various places as follows: - - ```java - if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { - Hooks.onEachOperator(TokenLinkingSubscriber.class.getName(), tokenLift()); - } - ``` - -* `Schedulers_Instrumentation` and `HttpTrafficHandler_Instrumentation` - Both of these classes serve as entry points to add the `TokenLinkingSubscriber` sub-hook. - -* Scheduler `Task`s - Reactor Core Scheduler tasks that execute on asynchronous threads. These are instrumented as points to link `Tokens`. - -## Troubleshooting - -In cases where a `Transaction` gets named `/NettyDispatcher` (or named after a security `Filter`) it usually indicates that context was lost somewhere in -reactor code and that activity on threads where other instrumentation would typically apply could not be linked to the originating `Transaction` thread. -Figuring out how to propagate and link a `Token` across the threads should resolve the issue. diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java b/instrumentation/netty-reactor-0.8.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java index 541977f380..cf758c4804 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java @@ -17,14 +17,8 @@ import java.util.function.BiFunction; import java.util.function.Function; -/** - * Implementation of a reactor.core.CoreSubscriber (a Context aware subscriber) that can be added as - * a lifecycle hook on Flux/Mono operators to propagate, retrieve, and link Tokens across async contexts. - * - * Based on OpenTelemetry code: - * https://github.com/open-telemetry/opentelemetry-java-instrumentation/blob/main/instrumentation/reactor-3.1/library/src/main/java/io/opentelemetry/instrumentation/reactor/TracingSubscriber.java - * @param - */ +// Based on OpenTelemetry code +// https://github.com/open-telemetry/opentelemetry-java-instrumentation/blob/main/instrumentation/reactor-3.1/library/src/main/java/io/opentelemetry/instrumentation/reactor/TracingSubscriber.java public class TokenLinkingSubscriber implements CoreSubscriber { private final Token token; private final Subscriber subscriber; @@ -33,7 +27,7 @@ public class TokenLinkingSubscriber implements CoreSubscriber { public TokenLinkingSubscriber(Subscriber subscriber, Context ctx) { this.subscriber = subscriber; this.context = ctx; - // newrelic-token is added by spring-webflux instrumentation of ServerWebExchange + // newrelic-token is added by spring-webflux instrumentation this.token = ctx.getOrDefault("newrelic-token", null); } diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java index b573bfefe9..abe1cd448c 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java @@ -14,12 +14,6 @@ @Weave(originalName = "reactor.core.publisher.Hooks") public abstract class Hooks_Instrumentation { - - /* - * Note that sub-hooks are cumulative. We want to avoid setting the same sub-hooks - * more than once, so we set this boolean to true the first time we set a sub-hook. - * if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { Hooks.onEachOperator(...) } - */ @NewField public static AtomicBoolean instrumented = new AtomicBoolean(false); } diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java index 4095149fa9..4a624921f0 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java @@ -14,8 +14,6 @@ @Weave(originalName = "reactor.core.scheduler.InstantPeriodicWorkerTask") final class InstantPeriodicWorkerTask_Instrumentation { - // We need to be able to link the Token here when executing on a supplied Scheduler - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java index 988d33ce26..961edd6f77 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java @@ -14,8 +14,6 @@ @Weave(originalName = "reactor.core.scheduler.PeriodicWorkerTask") final class PeriodicWorkerTask_Instrumentation { - // We need to be able to link the Token here when executing on a supplied Scheduler - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java index fda06f032a..86d01bced8 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java @@ -15,7 +15,6 @@ final class SchedulerTask_Instrumentation { // We need to be able to link the Token here when executing on a supplied Scheduler via Mono::publishOn - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java deleted file mode 100644 index 29ae1e901a..0000000000 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java +++ /dev/null @@ -1,45 +0,0 @@ -/* - * Copyright 2021 New Relic Corporation. All rights reserved. - * SPDX-License-Identifier: Apache-2.0 - */ - -package reactor.core.scheduler; - -import com.newrelic.api.agent.weaver.MatchType; -import com.newrelic.api.agent.weaver.Weave; -import com.newrelic.api.agent.weaver.Weaver; -import com.nr.instrumentation.reactor.netty.TokenLinkingSubscriber; -import reactor.core.publisher.Hooks; -import reactor.core.publisher.Hooks_Instrumentation; - -import static com.nr.instrumentation.reactor.netty.TokenLinkingSubscriber.tokenLift; - -@Weave(type = MatchType.BaseClass, originalName = "reactor.core.scheduler.Schedulers") -public abstract class Schedulers_Instrumentation { - - @Weave(type = MatchType.ExactClass, originalName = "reactor.core.scheduler.Schedulers$CachedScheduler") - static class CachedScheduler { - final Scheduler cached; - final String key; - - CachedScheduler(String key, Scheduler cached) { - /* - * Add tokenLift hook if it hasn't already been added. This allows for tokens to be retrieved from - * the current context and linked across threads at various points of the Flux/Mono lifecycle. - * - * When using Netty Reactor with SpringBoot this hook will be added by the HttpTrafficHandler_Instrumentation - * but when using other embedded web servers (e.g. Tomcat, Jetty, Undertow) the HttpTrafficHandler class - * doesn't get loaded and thus the hook isn't added. This ensures that the hook is added in a common code - * path before any Scheduler Tasks are spun off on new threads. - */ - if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { - Hooks.onEachOperator(TokenLinkingSubscriber.class.getName(), tokenLift()); - } - - this.cached = Weaver.callOriginal(); - this.key = Weaver.callOriginal(); - } - - } - -} diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java index 76867aca47..027fe89c06 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java @@ -14,8 +14,6 @@ @Weave(originalName = "reactor.core.scheduler.WorkerTask") final class WorkerTask_Instrumentation { - // We need to be able to link the Token here when executing on a supplied Scheduler - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java index d998d6d2e4..caeb301cde 100644 --- a/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java +++ b/instrumentation/netty-reactor-0.8.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java @@ -19,14 +19,6 @@ @Weave(originalName = "reactor.netty.http.server.HttpTrafficHandler") class HttpTrafficHandler_Instrumentation { public void channelRead(ChannelHandlerContext ctx, Object msg) { - - /* - * Add tokenLift hook if it hasn't already been added. This allows for tokens to be retrieved from - * the current context and linked across threads at various points of the Flux/Mono lifecycle. - * - * This hook will only be added when using Netty Reactor with SpringBoot. When using other embedded web - * servers (e.g. Tomcat, Jetty, Undertow) the Schedulers_Instrumentation class will add the hook. - */ if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { Hooks.onEachOperator(TokenLinkingSubscriber.class.getName(), tokenLift()); } diff --git a/instrumentation/netty-reactor-0.9.0/README.md b/instrumentation/netty-reactor-0.9.0/README.md deleted file mode 100644 index 6e8c9267be..0000000000 --- a/instrumentation/netty-reactor-0.9.0/README.md +++ /dev/null @@ -1,36 +0,0 @@ -# Reactor Netty Instrumentation - -Instrumentation for Reactor Netty server and also some widely used Reactor Core library code. - -This module is largely responsible for instrumenting the Reactor Core library to facilitate the passing, retrieval, -and linking of `Tokens` across contexts to tie asynchronous threads together for individual `Transactions`. - -This instrumentation is dependent on other instrumentation modules to start a `Transaction`. -Typically, the `netty-n.n` modules work with this instrumentation and will start a `Transaction` (see `NettyDispatcher#channelRead`). - -Most commonly this instrumentation comes into play with SpringBoot usage, in which case the `spring` and `spring-webflux` -instrumentation modules also apply and should result in `Transactions` being renamed after the Spring controller. - -## Key Components - -* `TokenLinkingSubscriber` - Implementation of a `reactor.core.CoreSubscriber` (a `Context` aware subscriber) that can be added as - a lifecycle hook on `Flux`/`Mono` operators to propagate, retrieve, and link `Tokens` across async contexts. This is done in various places as follows: - - ```java - if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { - Hooks.onEachOperator(TokenLinkingSubscriber.class.getName(), tokenLift()); - } - ``` - -* `Schedulers_Instrumentation` and `HttpTrafficHandler_Instrumentation` - Both of these classes serve as entry points to add the `TokenLinkingSubscriber` sub-hook. - -* Scheduler `Task`s - Reactor Core Scheduler tasks that execute on asynchronous threads. These are instrumented as points to link `Tokens`. - -## Troubleshooting - -In cases where a `Transaction` gets named `/NettyDispatcher` (or named after a security `Filter`) it usually indicates that context was lost somewhere in -reactor code and that activity on threads where other instrumentation would typically apply could not be linked to the originating `Transaction` thread. -Figuring out how to propagate and link a `Token` across the threads should resolve the issue. diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java b/instrumentation/netty-reactor-0.9.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java index 541977f380..cf758c4804 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/com/nr/instrumentation/reactor/netty/TokenLinkingSubscriber.java @@ -17,14 +17,8 @@ import java.util.function.BiFunction; import java.util.function.Function; -/** - * Implementation of a reactor.core.CoreSubscriber (a Context aware subscriber) that can be added as - * a lifecycle hook on Flux/Mono operators to propagate, retrieve, and link Tokens across async contexts. - * - * Based on OpenTelemetry code: - * https://github.com/open-telemetry/opentelemetry-java-instrumentation/blob/main/instrumentation/reactor-3.1/library/src/main/java/io/opentelemetry/instrumentation/reactor/TracingSubscriber.java - * @param - */ +// Based on OpenTelemetry code +// https://github.com/open-telemetry/opentelemetry-java-instrumentation/blob/main/instrumentation/reactor-3.1/library/src/main/java/io/opentelemetry/instrumentation/reactor/TracingSubscriber.java public class TokenLinkingSubscriber implements CoreSubscriber { private final Token token; private final Subscriber subscriber; @@ -33,7 +27,7 @@ public class TokenLinkingSubscriber implements CoreSubscriber { public TokenLinkingSubscriber(Subscriber subscriber, Context ctx) { this.subscriber = subscriber; this.context = ctx; - // newrelic-token is added by spring-webflux instrumentation of ServerWebExchange + // newrelic-token is added by spring-webflux instrumentation this.token = ctx.getOrDefault("newrelic-token", null); } diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java index b573bfefe9..abe1cd448c 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/publisher/Hooks_Instrumentation.java @@ -14,12 +14,6 @@ @Weave(originalName = "reactor.core.publisher.Hooks") public abstract class Hooks_Instrumentation { - - /* - * Note that sub-hooks are cumulative. We want to avoid setting the same sub-hooks - * more than once, so we set this boolean to true the first time we set a sub-hook. - * if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { Hooks.onEachOperator(...) } - */ @NewField public static AtomicBoolean instrumented = new AtomicBoolean(false); } diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java index 4095149fa9..4a624921f0 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/InstantPeriodicWorkerTask_Instrumentation.java @@ -14,8 +14,6 @@ @Weave(originalName = "reactor.core.scheduler.InstantPeriodicWorkerTask") final class InstantPeriodicWorkerTask_Instrumentation { - // We need to be able to link the Token here when executing on a supplied Scheduler - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java index 988d33ce26..961edd6f77 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/PeriodicWorkerTask_Instrumentation.java @@ -14,8 +14,6 @@ @Weave(originalName = "reactor.core.scheduler.PeriodicWorkerTask") final class PeriodicWorkerTask_Instrumentation { - // We need to be able to link the Token here when executing on a supplied Scheduler - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java index fda06f032a..86d01bced8 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/SchedulerTask_Instrumentation.java @@ -15,7 +15,6 @@ final class SchedulerTask_Instrumentation { // We need to be able to link the Token here when executing on a supplied Scheduler via Mono::publishOn - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java deleted file mode 100644 index 9bef1d7d91..0000000000 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/Schedulers_Instrumentation.java +++ /dev/null @@ -1,44 +0,0 @@ -/* - * Copyright 2021 New Relic Corporation. All rights reserved. - * SPDX-License-Identifier: Apache-2.0 - */ - -package reactor.core.scheduler; - -import com.newrelic.api.agent.weaver.MatchType; -import com.newrelic.api.agent.weaver.Weave; -import com.newrelic.api.agent.weaver.Weaver; -import com.nr.instrumentation.reactor.netty.TokenLinkingSubscriber; -import reactor.core.publisher.Hooks; -import reactor.core.publisher.Hooks_Instrumentation; - -import static com.nr.instrumentation.reactor.netty.TokenLinkingSubscriber.tokenLift; - -@Weave(type = MatchType.BaseClass, originalName = "reactor.core.scheduler.Schedulers") -public abstract class Schedulers_Instrumentation { - - @Weave(type = MatchType.ExactClass, originalName = "reactor.core.scheduler.Schedulers$CachedScheduler") - static class CachedScheduler { - final Scheduler cached; - final String stringRepresentation; - - CachedScheduler(String key, Scheduler cached) { - /* - * Add tokenLift hook if it hasn't already been added. This allows for tokens to be retrieved from - * the current context and linked across threads at various points of the Flux/Mono lifecycle. - * - * When using Netty Reactor with SpringBoot this hook will be added by the HttpTrafficHandler_Instrumentation - * but when using other embedded web servers (e.g. Tomcat, Jetty, Undertow) the HttpTrafficHandler class - * doesn't get loaded and thus the hook isn't added. This ensures that the hook is added in a common code - * path before any Scheduler Tasks are spun off on new threads. - */ - if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { - Hooks.onEachOperator(TokenLinkingSubscriber.class.getName(), tokenLift()); - } - - this.cached = Weaver.callOriginal(); - this.stringRepresentation = Weaver.callOriginal(); - } - } - -} diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java index 76867aca47..027fe89c06 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/core/scheduler/WorkerTask_Instrumentation.java @@ -14,8 +14,6 @@ @Weave(originalName = "reactor.core.scheduler.WorkerTask") final class WorkerTask_Instrumentation { - // We need to be able to link the Token here when executing on a supplied Scheduler - // A Token should be available on the thread that this task executes on if tokenLift() was added to Hooks.onEachOperator @Trace(async = true, excludeFromTransactionTrace = true) public Void call() { return Weaver.callOriginal(); diff --git a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java index d998d6d2e4..caeb301cde 100644 --- a/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java +++ b/instrumentation/netty-reactor-0.9.0/src/main/java/reactor/netty/http/server/HttpTrafficHandler_Instrumentation.java @@ -19,14 +19,6 @@ @Weave(originalName = "reactor.netty.http.server.HttpTrafficHandler") class HttpTrafficHandler_Instrumentation { public void channelRead(ChannelHandlerContext ctx, Object msg) { - - /* - * Add tokenLift hook if it hasn't already been added. This allows for tokens to be retrieved from - * the current context and linked across threads at various points of the Flux/Mono lifecycle. - * - * This hook will only be added when using Netty Reactor with SpringBoot. When using other embedded web - * servers (e.g. Tomcat, Jetty, Undertow) the Schedulers_Instrumentation class will add the hook. - */ if (!Hooks_Instrumentation.instrumented.getAndSet(true)) { Hooks.onEachOperator(TokenLinkingSubscriber.class.getName(), tokenLift()); }