Class OpenTelemetryHttpServerFilter
- All Implemented Interfaces:
HttpExecutionStrategyInfluencer
,StreamingHttpServiceFilterFactory
,ExecutionStrategyInfluencer<HttpExecutionStrategy>
StreamingHttpService
that supports
open telemetry.
The filter gets a Tracer
with "io.servicetalk" instrumentation scope name.
Append this filter before others that are expected to see Scope
for this request/response. Filters
appended after this filter that use operators with the after* prefix on
response meta data
or the response message body
(e.g. Publisher.afterFinally(Runnable)
) will execute after this filter invokes Scope.close()
and
therefore will not see the Span
for the current request/response.
-
Constructor Summary
ConstructorsConstructorDescriptionCreate a new Instance, searching for any instance of an opentelemetry available.OpenTelemetryHttpServerFilter
(io.opentelemetry.api.OpenTelemetry openTelemetry) Deprecated.OpenTelemetryHttpServerFilter
(OpenTelemetryOptions opentelemetryOptions) Create a new instance. -
Method Summary
Modifier and TypeMethodDescriptioncreate
(StreamingHttpService service) Create aStreamingHttpServiceFilter
using the providedStreamingHttpService
.final HttpExecutionStrategy
Return anExecutionStrategy
that describes the offloads required by the influencer.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface io.servicetalk.http.api.HttpExecutionStrategyInfluencer
influenceStrategy, requiredOffloads
-
Constructor Details
-
OpenTelemetryHttpServerFilter
Deprecated.this method is internal, no user should be setting theOpenTelemetry
as it is obtained by usingGlobalOpenTelemetry.get()
and there should be no other implementations but the one available in the classpath, this constructor will be removed in the future releases. UseOpenTelemetryHttpServerFilter(OpenTelemetryOptions)
orOpenTelemetryHttpServerFilter()
instead.Create a new instance.- Parameters:
openTelemetry
- theOpenTelemetry
.
-
OpenTelemetryHttpServerFilter
public OpenTelemetryHttpServerFilter()Create a new Instance, searching for any instance of an opentelemetry available. -
OpenTelemetryHttpServerFilter
Create a new instance.- Parameters:
opentelemetryOptions
- extra options to create the opentelemetry filter
-
-
Method Details
-
create
Description copied from interface:StreamingHttpServiceFilterFactory
Create aStreamingHttpServiceFilter
using the providedStreamingHttpService
.- Specified by:
create
in interfaceStreamingHttpServiceFilterFactory
- Parameters:
service
-StreamingHttpService
to filter- Returns:
StreamingHttpServiceFilter
using the providedStreamingHttpService
.
-
requiredOffloads
Description copied from interface:HttpExecutionStrategyInfluencer
Return anExecutionStrategy
that describes the offloads required by the influencer.The provided default implementation requests offloading of all operations. Implementations that require no offloading should be careful to return
HttpExecutionStrategies.offloadNone()
rather thanHttpExecutionStrategies.offloadNever()
. Implementations should avoid returningHttpExecutionStrategies.defaultStrategy()
, instead returning the strategy they require orHttpExecutionStrategies.offloadAll()
if offloading for all paths is required (safe default).- Specified by:
requiredOffloads
in interfaceExecutionStrategyInfluencer<HttpExecutionStrategy>
- Specified by:
requiredOffloads
in interfaceHttpExecutionStrategyInfluencer
- Returns:
- the
ExecutionStrategy
required by the influencer.
-
OpenTelemetry
as it is obtained by usingGlobalOpenTelemetry.get()
and there should be no other implementations but the one available in the classpath, this constructor will be removed in the future releases.