我一直在许多脚本中广泛使用Log4perl。如果已记录任何WARN
或ERROR
消息,我想扩充这些脚本以设置错误代码。基于现有文档,我找不到任何明显的方法。
我想避免对现有脚本进行强力重写,以便对每个WARN
或ERROR
日志消息进行检查;如果可能的话,我更喜欢在脚本退出之前处理它,就像这个伪代码一样:
if $log->has_warnings_or_errors then
exit 1
else
exit 0
是否有任何简单的方法可以调用Log4Perl来确定当前记录器是否存在某些级别的消息?
答案 0 :(得分:6)
使用appender。
<强> MyCounter.pm:强>
package MyCounter;
use warnings;
use strict;
use Log::Log4perl::Level;
sub new {
my($class,%arg) = @_;
bless {} => $class;
}
sub log {
my($self,%arg) = @_;
++$self->{ $arg{log4p_level} };
}
sub howmany {
my($self,@which) = @_;
my $total = 0;
$total += ($self->{$_} || 0) for @which;
$total;
}
1;
<强> MYPROG:强>
#! /usr/bin/perl
use warnings;
use strict;
use Log::Log4perl;
my $conf = q(
log4perl.category.MyLogger = INFO, Screen
log4perl.appender.Screen = Log::Log4perl::Appender::Screen
log4perl.appender.Screen.layout = Log::Log4perl::Layout::SimpleLayout
);
Log::Log4perl->init(\$conf);
my $l = Log::Log4perl->get_logger("MyLogger");
my $counter = Log::Log4perl::Appender->new("MyCounter");
$l->add_appender($counter);
$l->warn("warning");
$l->info("info");
$l->error("incorrect");
$l->fatal("really bad, man");
print $counter->howmany(qw/ WARN ERROR FATAL /), "\n";
exit ($counter->howmany(qw/ WARN ERROR FATAL /) ? 1 : 0);
输出:
$ ./myprog WARN - warning INFO - info ERROR - incorrect FATAL - really bad, man 3 $ echo $? 1
评论...->warn
,...->error
和...->fatal
行以获取
$ ./myprog INFO - info 0 $ echo $? 0
答案 1 :(得分:0)
您可以使用wrapper并编写增加计数器的自定义fatal
,error
和warn
方法以及返回该计数器值的访问者。