Annotations
Você está visualizando a versão em versão em inglês desta página porque ela ainda não foi traduzida. Possui interesse em ajudar? Veja como contribuir.
For most users, the out-of-the-box instrumentation is completely sufficient and
nothing more needs to be done. Sometimes, however, users wish to create
spans for their own custom code without
having to change much code. The WithSpan and SpanAttribute annotations
support those use cases.
Dependencies
You’ll need to add a dependency on the
opentelemetry-instrumentation-annotations library to use the @WithSpan
annotation.
<dependencies>
  <dependency>
    <groupId>io.opentelemetry.instrumentation</groupId>
    <artifactId>opentelemetry-instrumentation-annotations</artifactId>
    <version>2.20.1</version>
  </dependency>
</dependencies>
Creating spans around methods with @WithSpan
To create a span that instruments a
particular method, annotate the method with @WithSpan.
import io.opentelemetry.instrumentation.annotations.WithSpan;
public class MyClass {
  @WithSpan
  public void myMethod() {
      <...>
  }
}
Each time the application invokes the annotated method, it creates a span that
denotes its duration and provides any thrown exceptions. By default, the span
name will be <className>.<methodName>, unless a name is provided through the
value annotation parameter.
If the return type of the method annotated by @WithSpan is one of the
future- or promise-like
types listed below, then the span will not be ended until the future completes.
- java.util.concurrent.CompletableFuture
- java.util.concurrent.CompletionStage
- com.google.common.util.concurrent.ListenableFuture
- org.reactivestreams.Publisher
- reactor.core.publisher.Mono
- reactor.core.publisher.Flux
- io.reactivex.Completable
- io.reactivex.Maybe
- io.reactivex.Single
- io.reactivex.Observable
- io.reactivex.Flowable
- io.reactivex.parallel.ParallelFlowable
Parameters
The @WithSpan attribute supports the following optional parameters to allow
customization of spans:
| name | type | default | description | 
|---|---|---|---|
| value | String | "" | The span name. If not specified, the default <className>.<methodName>is used. | 
| kind | SpanKind(enum) | INTERNAL | The kind of span. | 
| inheritContext | boolean | true | Since 2.14.0. Controls whether or not the new span will be parented in the existing (current) context. If false, a new context is created. | 
Example parameter usage:
@WithSpan(kind = SpanKind.CLIENT, inheritContext = false, value = "my span name")
public void myMethod() {
    <...>
}
@WithSpan("my span name")
public void myOtherMethod() {
    <...>
}
Adding attributes to the span with @SpanAttribute
When a span is created for an annotated
method, the values of the arguments to the method invocation can be
automatically added as attributes
to the created span. Simply annotate the method parameters with the
@SpanAttribute annotation:
import io.opentelemetry.instrumentation.annotations.SpanAttribute;
import io.opentelemetry.instrumentation.annotations.WithSpan;
public class MyClass {
    @WithSpan
    public void myMethod(@SpanAttribute("parameter1") String parameter1,
        @SpanAttribute("parameter2") long parameter2) {
        <...>
    }
}
Unless specified as an argument to the annotation, the attribute name will be
derived from the formal parameter names if they are compiled into the .class
files by passing the -parameters option to the javac compiler.
Suppressing @WithSpan instrumentation
Suppressing @WithSpan is useful if you have code that is over-instrumented
using @WithSpan and you want to suppress some of them without modifying the
code.
System property:
otel.instrumentation.opentelemetry-instrumentation-annotations.exclude-methods
Environment variable:
OTEL_INSTRUMENTATION_OPENTELEMETRY_INSTRUMENTATION_ANNOTATIONS_EXCLUDE_METHODSDescription:
Suppress
@WithSpan instrumentation for specific methods. Format is
my.package.MyClass1[method1,method2];my.package.MyClass2[method3].
Creating spans around methods with otel.instrumentation.methods.include
In cases where you are unable to modify the code, you can still configure the Java agent to capture spans around specific methods.
System property:
otel.instrumentation.methods.include
Environment variable:
OTEL_INSTRUMENTATION_METHODS_INCLUDEDescription:
Add
instrumentation for specific methods in lieu of @WithSpan. Format is
my.package.MyClass1[method1,method2];my.package.MyClass2[method3].
If a method is overloaded (appears more than once on the same class with the same name but different parameters), all versions of the method will be instrumented.
Next steps
Beyond the use of annotations, the OpenTelemetry API allows you to obtain a tracer that can be used for custom instrumentation.
Feedback
Was this page helpful?
Thank you. Your feedback is appreciated!
Please let us know how we can improve this page. Your feedback is appreciated!