NAME
OpenTracing::GlobalTracer - Easy Access to the Tracer Singleton
SYNOPSIS
use OpenTracing::GlobalTracer qw/$TRACER/;
my $foo_tracer = OpenTracing::Implementation::Foo::Tracer->new( );
OpenTracing::GlobalTracer->set_global_trace( $foo_tracer );
and in the various part of the code:
my $global_tracer = OpenTracing::GlobalTracer->get_global_tracer( );
my $span = $global_tracer->get_active_span;
my $scope = $TRACER->start_active_span( $operation_name );
DESCRIPTION
This module give easy access to the OpenTracing singleton.
During import, when `use`ing the module, it can take the name of a variable to use in the current scope.
The modules provide two methods, `set_global_tracer` and `get_global_tracer`.
If none is set (or cleared), per definition, it will give back a 'NoOp' implementation.
CLASS METHODS
set_global_tracer
OpenTracing::GlobalTracer->set_global_trace( $tracer );
Sets the global tracer singleton.
get_global_tracer
my $global_tracer = OpenTracing::GlobalTracer->get_global_tracer( );
Returns a global tracer if some is set. If none is set, it will return the OpenTracing::Implementation::NoOp implementation, compliant to the definition to prevent crashing.
ENVIRONMENT VARIABLES
OPENTRACING_GLOBALTRACER_DEFAULT
This variable can be set to override the default NoOp implementation.
CAVEATS
When using the $TRACER
variable, one still needs to be careful, it could be undef
if no tracer wasn't initialised, or explicitly been erased. This may result in errors like "can't use method ... on undef".
AUTHOR
Theo van Hoesel <tvanhoesel@perceptyx.com>
COPYRIGHT AND LICENSE
'OpenTracing GlobalTracer' is Copyright (C) 2019, Perceptyx Inc
This package is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0.
This package 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.