NAME
OpenTracing::Role::Span - Role for OpenTracing implementations.
SYNOPSIS
package OpenTracing::Implementation::MyBackendService::Span;
use Moo;
...
with 'OpenTracing::Role::Span'
1;
DESCRIPTION
This is a Role for OpenTracing implenetations that are compliant with the OpenTracing::Interface.
With the exception of calls to get_context()
(which are always allowed), finish()
must be the last call made to any span instance, and to do otherwise leads to undefined behavior (but not returning an exception).
IMPLEMENTED OPENTRACING METHODS
The following methods from OpenTracing::Interface have been implemented. See their documentation for more details.
get_context
Yields the SpanContext
for this Span
. Note that the return value of get_context()
is still valid after a call to finish(), as is a call to get_context() after a call to finish().
See "get_context" in OpenTracing::Interface::Span.
overwrite_operation_name
Changes the operation name.
See "overwrite_operation_name" in OpenTracing::Interface::Span.
finish
Sets the end timestamp and finalizes Span state.
See "finish" in OpenTracing::Interface::Span.
add_tag
Adds a tag to the span.
See "add_tag" in OpenTracing::Interface::Span.
add_tags
Adds multiple tags to the span at the same time
See "add_tags" in OpenTracing::Interface::Span.
log_data
Adds a log record to the span.
See "log_data" in OpenTracing::Interface::Span.
add_baggage_item
Sets a key:value pair on this Span and its SpanContext that also propagates to descendants of this Span.
See "add_baggage_item" in OpenTracing::Interface::Span.
add_baggage_items
Sets multiple baggage_items
at once.
See "add_baggage_items" in OpenTracing::Interface::Span.
get_baggage_item
Returns either the corresponding baggage value, or undef
when such a value was missing.
See "get_baggage_item" in OpenTracing::Interface::Span.
get_baggage_items
This will return a Hash of key/value pairs.
See "get_baggage_items" in OpenTracing::Interface::Span.
WARNING
Never use any of attributes or methods below in any integration!
Only methods mentioned in the Public OpenTracing::Interface are safe to be used in any integration or when instrumenting applications.
ATTRIBUTES
operation_name
A required Str
Type value, for the operation name.
See get_operation_name
and overwrite_operation_name
.
start_time
A read-only PositiveOrZeroNum
floatingpoint that defaults to the number of seconds since epoch.
finish_time
A PositiveOrZeroNum
floatingpoint that can only be set by calling finish
.
See finish
and has_finished
.
tags
An optional HashRef
of Value
s that defaults to an empty hash reference.
See add_tag
, add_tags
, get_tag
, and get_tags
.
context
A required read-only SpanContext type.
Although a read-only, it will get swapped for a clone_with
result when trying to add any baggage_item
, since SpanContext
is inmutable.
See get_context
, add_baggage_item
, and add_baggage_items
.
child_of
A optional Span
or SpanContext
.
Note: this may not be the correct design and this attribute may disapear.
See parent_span_id
.
on_finish
Maybe a CodeRef that will gets executed when finish
gets called. Its only parameter, is the Span
invocant itself.
Its usefulnes currently is for dealing with c<span> inside Tracer
.
See finish
.
INSTANCE METHODS
get_operation_name
The accessor for the operatation_name
- Returns
-
Str
has_finished
The state wether or not finish
has been called or not.
- Returns
-
Bool
get_span_id
The identifier of the Span
itself, through its span context.
- Returns
-
Uuid
get_parent_span_id
The identifier of the parent Span
- Returns
-
Uuid
duration
The time (in seconds) between start and finish. This will croak
when either start_time
or finish_time
has not been set yet.
epoch_floatingpoint
A helper method to make it explicit that the time is in floating point, and not the usual integer number of seconds since epoch.
SEE ALSO
- OpenTracing::Types
-
Type constraints for checking Interfaces
- OpenTracing::Interface::Span
-
A role that defines the Span interface
AUTHOR
Theo van Hoesel <tvanhoesel@perceptyx.com>
COPYRIGHT AND LICENSE
'OpenTracing API for Perl' is Copyright (C) 2019 .. 2020, Perceptyx Inc
This library is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0.
This library is distributed in the hope that it will be useful, but it is provided "as is" and without any express or implied warranties.
For details, see the full text of the license in the file LICENSE.