Blocking instrumentation in Java

There are multiple ways to block instrumentation in Java. Transactions that are ignored will not be included in the metrics you see in the New Relic user interface.

Block transactions with ServletRequest

To ignore a web transaction, set a ServletRequest attribute named com.newrelic.agent.IGNORE to true during the request:

request.setAttribute("com.newrelic.agent.IGNORE", true);

To specify URLs to ignore, create a servlet filter which sets that attribute and apply the filter to the servlet you want to ignore. The filter will have access to the request URI if you need to ignore specific URLs.

Block transactions with annotation

To tell the Java agent to ignore transactions using annotations:

  1. Define an annotation called NewRelicIgnoreTransaction:

    public @interface NewRelicIgnoreTransaction {
  2. Apply the annotation to the methods or classes you want to ignore. For example:

    public void ignore() {

If a transaction calls a method or class annotated with @NewRelicIgnoreTransaction, the transaction is ignored. This means it does not contribute to the overall Apdex score; and the transaction trace and performance data is not reported.

Ignore apdex but not traces

You can also prevent the transaction from contributing to the Apdex score but still be used in transaction traces. Define a NewRelicIgnoreApdex annotation:

public @interface NewRelicIgnoreApdex {

For more help

You can also use the API to ignore a transaction.

Join the discussion about Java monitoring in the New Relic Community Forum! The Community Forum is a public platform to discuss and troubleshoot your New Relic toolset.

If you need additional help, get support at