我目前正在使用以下方式将 INFO 及更高版本发送到 STDOUT:
Log::Log4perl->easy_init({level=>("$INFO"), layout=>"%d %p - %m%n", file=>"STDOUT"});
如何将 ERROR 及更高版本发送到 STDERR?
这个任务对于 easy_init 设置来说可能太多了,因为你需要使用过滤器来达到那个效果。通过正常设置,您可以执行以下操作:
use Log::Log4perl qw(:easy);
Log::Log4perl->init(\ qq{
log4perl.logger = INFO, AppInfo, AppError
# Filter to match level ERROR
log4perl.filter.MatchError = Log::Log4perl::Filter::LevelMatch
log4perl.filter.MatchError.LevelToMatch = ERROR
log4perl.filter.MatchError.AcceptOnMatch = true
# Filter to match level INFO
log4perl.filter.MatchInfo = Log::Log4perl::Filter::LevelMatch
log4perl.filter.MatchInfo.LevelToMatch = INFO
log4perl.filter.MatchInfo.AcceptOnMatch = true
# Error appender
log4perl.appender.AppError = Log::Log4perl::Appender::Screen
log4perl.appender.AppError.stderr = 1
log4perl.appender.AppError.layout = SimpleLayout
log4perl.appender.AppError.Filter = MatchError
# Info appender
log4perl.appender.AppInfo = Log::Log4perl::Appender::Screen
log4perl.appender.AppInfo.stderr = 0
log4perl.appender.AppInfo.layout = SimpleLayout
log4perl.appender.AppInfo.Filter = MatchInfo
});
ERROR "Error";
INFO "Info";