NAME

Log::Log4perl::OpenTracing - inject logs with OpenTracing SpanContext

SYNOPSIS

use Log::Log4perl;
use Log::Log4perl::OpenTracing;

my $config = q{
    log4perl.rootLogger           = TRACE, json
    log4perl.appender.json        = Log::Log4perl::Appender::File
    log4perl.appender.json.layout = Log::Log4perl::Layout::JSON::Readable
    log4perl.appender.json.layout.field.message  = %m{chomp}
    log4perl.appender.json.layout.field.time     = %d
    log4perl.appender.json.layout.field.trace-id = %O{opentracing.trace_id}
    log4perl.appender.json.layout.field.span-id  = %O{opentracing.span_id}
    log4perl.appender.json.layout.canonical      = 1
    log4perl.appender.json.layout.first_fields   = time, trace-id, span-id
};

Log::Log4perl::init( \$config );

DESCRIPTION

This module bridges the gap between Logging and OpenTracing. Some tracing backends are capable to correlate log-messages with spans and traces. This could be achieved by adding the span-id and the trace-id to the logfiles.

This module introduces a new %O (capital letter 'O') placeholder that can be used with PatternLayouts.

The information that is availabale, depends on the implementation specific inject_context method for a hash reference. Since OpenTracing has no control on what data is being exposed from that inject_context method, nor what keys are used, or any data structures (like baggage_items), this module uses a 'dotted' key syntax for nested data. Check with the specific implementation for what data is injected.

CAVEAT

This module uses Hash::Fold to flatten the data structure that come from inject_context. That flettening may potentially lead to issues where data structures might lead to the same 'flattened' key if one would forge a structure that already has a . (dot) in its keys.

SEE ALSO

OpenTracing::Interface::Tracer

A role that defines the Tracer interface.

Log::Log4perl

Log4j implementation for Perl

AUTHOR

Theo van Hoesel <tvanhoesel@perceptyx.com>

COPYRIGHT AND LICENSE

'Log::Log4perl::OpenTracing' is Copyright (C) 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 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.