Provides OpenTelemetry instrumentation for Spring's WebClient
and Webflux server.
For this instrumentation, the minimum supported version of Spring Webflux is 5.3.0.
For Maven, add to your pom.xml
:
<dependencies>
<dependency>
<groupId>io.opentelemetry.instrumentation</groupId>
<artifactId>opentelemetry-spring-webflux-5.3</artifactId>
<version>OPENTELEMETRY_VERSION</version>
</dependency>
<!-- This artifact should already be present in your application -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webflux</artifactId>
<version>SPRING_VERSION</version>
</dependency>
</dependencies>
For Gradle, add to your dependencies:
implementation("io.opentelemetry.instrumentation:opentelemetry-spring-webflux-5.3:OPENTELEMETRY_VERSION")
// this artifact should already be present in your application
implementation("org.springframework:spring-webflux:SPRING_VERSION")
SpringWebfluxTelemetry
can emit a client span for each request sent using WebClient
by
implementing
the ExchangeFilterFunction
interface.
SpringWebfluxTelemetry
can also emit a server span for each request received, by implementing
a WebFilter
and using the OpenTelemetry Reactor instrumentation to ensure context is
passed around correctly.
The WebClient
instrumentation will emit the error.type
attribute with value cancelled
whenever
an outgoing HTTP request is cancelled.
Here is how to set up client and server instrumentation respectively:
import io.opentelemetry.instrumentation.spring.webflux.v5_3.SpringWebfluxTelemetry;
@Configuration
public class WebClientConfig {
private final SpringWebfluxTelemetry webfluxTelemetry;
public WebClientConfig(OpenTelemetry openTelemetry) {
this.webfluxTelemetry = SpringWebfluxTelemetry.builder(openTelemetry).build();
}
// Adds instrumentation to WebClients
@Bean
public WebClient.Builder webClient() {
WebClient webClient = WebClient.create();
return webClient.mutate().filters(webfluxTelemetry::addClientTracingFilter);
}
// Adds instrumentation to Webflux server
@Bean
public WebFilter webFilter() {
return webfluxTelemetry.createWebFilterAndRegisterReactorHook();
}
}
Check out OpenTelemetry Manual Instrumentation to learn more about using the OpenTelemetry API to instrument your code.