我是Log4perl的新手,并试图弄清楚为什么我在以下设置中得到两个不同的记录器。我的理解是,这应该是一个单例,并且每次调用get_logger()都会返回该对象的相同实例。

Test.pm

#!/usr/bin/perl

package Example::Test;
use strict;
use warnings;
use Exporter;
our @ISA = qw(Exporter);
our @EXPORT = qw(test);

sub test
{
    my $logger = Log::Log4perl->get_logger();
    print $logger, "\n";
}


test.pl

#!/usr/bin/perl

use strict;
use warnings;
use Log::Log4perl;
use Example::Test;

# Logger configuration
Log::Log4perl->init('/etc/log4perl.conf');
my $logger = Log::Log4perl->get_logger();
print $logger, "\n";

my $engine = test();


输出量

Log::Log4perl::Logger=HASH(0x12093d0)
Log::Log4perl::Logger=HASH(0x29b4950)

最佳答案

您没有指定日志记录类别,因此您的代码等效于

Log::Log4perl->get_logger(__PACKAGE__);


其中模块中的__PACKAGE__Example::Test,脚本中的main

documentation


在Log4perl中,类别也称为“记录器”,它们都指相同的事物,并且这些术语可以互换使用。 Log::Log4perl使用类别来确定是否应在当前日志记录级别执行或抑制组件中的日志语句。大多数时候,这些类别只是日志语句所在的类。


通常,您可能希望每个模块都有一个单独的记录器,以便您可以不同方式处理来自代码库不同部分的日志消息。



另一方面,如果Example::Test应该是Log :: Log4perl的包装,则register it

package My::Wrapper;

use strict;
use warnings 'all';
use 5.010;

use Log::Log4perl;

Log::Log4perl->wrapper_register(__PACKAGE__);

sub foo {
    my $logger = Log::Log4perl->get_logger;

    say $logger;
    $logger->warn('foo');
}

1;


当您从包My::Wrapper::foo()调用main时,日志记录类别将为main::

08-17 12:04