首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Log4perl单例用法

Log4perl单例用法
EN

Stack Overflow用户
提问于 2016-11-03 17:40:12
回答 1查看 224关注 0票数 4

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

Test.pm

代码语言:javascript
复制
#!/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

代码语言:javascript
复制
#!/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();

输出

代码语言:javascript
复制
Log::Log4perl::Logger=HASH(0x12093d0)
Log::Log4perl::Logger=HASH(0x29b4950)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-03 20:29:48

您没有指定日志记录类别,所以您的代码执行相当于

代码语言:javascript
复制
Log::Log4perl->get_logger(__PACKAGE__);

其中,__PACKAGE__在模块中是Example::Test,在脚本中是main

来自文档

类别在Log4perl中也称为“记录器”,两者都引用相同的内容,这些术语可以互换使用。 Log::Log4perl使用类别来确定组件中的日志语句是否应该在当前日志记录级别上执行或抑制。大多数情况下,这些类别只是日志语句位于.

通常,您可能需要为每个模块设置一个单独的记录器,这样您就可以以不同的方式处理来自代码库不同部分的日志消息。

另一方面,如果Example::Test被认为是Log::Log4perl,注册它的包装器

代码语言:javascript
复制
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;

当您从package main调用main时,日志记录类别将是main::

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40407990

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档