Skip to content

Commit 22bd258

Browse files
authored
Merge pull request #2197 from newrelic/fix-httpclient-5-memory-issue
Fix memory issue with httpclient-5.0 instrumentation
2 parents 2c2422a + 4919640 commit 22bd258

File tree

2 files changed

+3
-1
lines changed

2 files changed

+3
-1
lines changed

instrumentation/httpclient-5.0/src/main/java/org/apache/hc/client5/http/async/HttpAsyncClient_Instrumentation.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,8 @@ public <T> Future<T> execute(
4141
Segment segment = InstrumentationUtils.startAsyncSegment();
4242

4343
HttpRequest request = ((BasicRequestProducer_Instrumentation)requestProducer).nrRequest;
44+
// null out the NewField to prevent memory issues
45+
((BasicRequestProducer_Instrumentation)requestProducer).nrRequest = null;
4446
InstrumentationUtils.doOutboundCAT(request, segment);
4547
Token token = NewRelic.getAgent().getTransaction().getToken();
4648

instrumentation/httpclient-5.0/src/main/java/org/apache/hc/core5/http/nio/support/BasicRequestProducer_Instrumentation.java

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@
1717
public class BasicRequestProducer_Instrumentation {
1818

1919
@NewField
20-
public final HttpRequest nrRequest;
20+
public HttpRequest nrRequest;
2121

2222
public BasicRequestProducer_Instrumentation(final HttpRequest request, final AsyncEntityProducer dataProducer) {
2323
nrRequest = request;

0 commit comments

Comments
 (0)