log4perl을 사용하여 모든 출력을 화면 및 파일에 기록하는 perl 스크립트가 있습니다. 문제는 특정 출력이 log4perl로 보내지지 않습니다.perl 스크립트의 모든 출력을 파일 및 화면으로 보냅니다.
스크립트 -
use strict;
use warnings 'FATAL' => 'all';
use Log::Log4perl;
use File::Find;
my $log_conf = "log4perl.conf";
Log::Log4perl::init($log_conf);
my $logp = Log::Log4perl->get_logger();
my $dirSource = 'C:\box';
sub doFileList {
$logp->info('doing dir compare');
find({ wanted => \&process_file, no_chdir => 1 }, $dirSource);
}
sub process_file {
if (-f $_) {
print "This is a file: $_\n";
} else {
print "This is not file: $_\n";
}
}
#main
$logp->info('start');
eval { doFileList(); };
if ([email protected]) {
$logp->error('error: ', [email protected]);
}
$logp->info('stop');
Log4perl 설정 - 여기
log4perl.rootLogger = DEBUG, screen, file
log4perl.appender.screen = Log::Log4perl::Appender::Screen
log4perl.appender.screen.stderr = 0
log4perl.appender.screen.layout = Log::Log4perl::Layout::PatternLayout
log4perl.appender.screen.layout.ConversionPattern = %d [%M:%L] %p %F{2} - %m%n
log4perl.appender.file = Log::Log4perl::Appender::File
log4perl.appender.file.filename = log/compare.log
log4perl.appender.file.mode = append
log4perl.appender.file.layout = Log::Log4perl::Layout::PatternLayout
log4perl.appender.file.layout.ConversionPattern = %d [%M:%L] %p %F{2} - %m%n
가 화면에 출력/IDE -
- 여기
2013/03/04 11:56:28 [main:::29] INFO DirCompare\DirCompare.pl - start
2013/03/04 11:56:28 [tools::dircompare::doFileList:16] INFO DirCompare\DirCompare.pl - doing dir compare
This is not file: C:\box
This is a file: C:\box\test01.JPG
This is a file: C:\box\test02.JPG
2013/03/04 11:56:28 [main:::34] INFO DirCompare\DirCompare.pl - stop
로그 파일에 출력이
2013/03/04 11:56:28 [main:::29] INFO DirCompare\DirCompare.pl - start
2013/03/04 11:56:28 [tools::dircompare::doFileList:16] INFO DirCompare\DirCompare.pl - doing dir compare
2013/03/04 11:56:28 [main:::34] INFO DirCompare\DirCompare.pl - stop
나는 log-> info 대신 print 문을 사용하고 있지만 log4perl 구성은 log4perl로 보내지는 방법에 관계없이 스크립트의 모든 출력이되도록하고 싶습니다.
어떻게 할 수 있습니까?