微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何将Perl警告记录到Log4perl日志中?

Log4perl一个很好的记录工具.

warnings编译也是必不可少的工具.

但是,当Perl脚本作为守护进程运行时,Perl警告将打印到STDERR中,而没有人可以看到它们,而不是相关程序的Log4perl日志文件.

有没有办法将Perl警告记录到Log4perl日志中?

例如,该代码将日志文件正常登录,但是如果作为守护进程运行,Perl警告将不会包含在日志中:

#!/usr/bin/env perl
use strict;
use warnings;

use Log::Log4perl qw(get_logger);

# Define configuration
my $conf = q(
                log4perl.logger                    = DEBUG,FileApp
                log4perl.appender.FileApp          = Log::Log4perl::Appender::File
                log4perl.appender.FileApp.filename = test.log
                log4perl.appender.FileApp.layout   = PatternLayout
);

# Initialize logging behavIoUr
Log::Log4perl->init( \$conf );

# Obtain a logger instance
my $logger = get_logger("Foo::Bar");
$logger->error("Oh my,an error!");

$SIG{__WARN__} = sub {
    #local $Log::Log4perl::caller_depth = $Log::Log4perl::caller_depth + 1;
    $logger->warn("WARN @_");
};

my $foo = 100;
my $foo = 44;

这仍然打印到STDERR:

"my" variable $foo masks earlier declaration in same scope at log.pl line 27.

并且日志文件没有捕获此警告.

解决方法

它在Log4perl FAQ中为 Some module prints messages to STDERR. How can I funnel them to Log::Log4perl?My program already uses warn() and die(). How can I switch to Log4perl?.

您的具体问题会增加您遇到编译时警告的皱纹,因此您需要尽可能早地调整FAQ建议,以便在编译时设置日志记录.在一个BEGIN块中,尽可能靠近源的顶端:

BEGIN {
     ... all of your logging setup
     }

您可以通过运行启用警告的语法检查来判断是否是编译时警告:

% perl -cw program

如果您在语法检查期间看到警告,则是编译时警告.

我宁愿在开发过程中捕获编译时警告.他们不应该通过生产系统.

原文地址:https://www.jb51.cc/Perl/172601.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐