我想限制使用 log4perl 创建的日志文件的大小。我不希望我的日志文件增长到超过 100mb;我只需要最后 100mb(或大约)的数据。理想情况下,它将截断较早的数据并仅保留最后一位。我知道 Log::Dispatch::FileRotate 模块,但这不太符合我的要求,因为我不想要多个日志文件。
这可能吗?
完整的代码,包括内联配置,如下(减去 use 语句):
my $log_conf = q/
log4perl.category = DEBUG, Logfile
log4perl.appender.Logfile = Log::Dispatch::FileRotate
log4perl.appender.Logfile.filename = sub { return get_log_fn(); }
log4perl.appender.Logfile.mode = truncate
log4perl.appender.Logfile.autoflush = 1
log4perl.appender.Logfile.size = 104857600
log4perl.appender.Logfile.layout = Log::Log4perl::Layout::PatternLayout
log4perl.appender.Logfile.layout.ConversionPattern = %d %P %M(%L) %p %m %n
/;
Log::Log4perl::init( \$log_conf );
my $logger = Log::Log4perl::get_logger();
INFO "Starting $0";
my $upper = 100000000;
for(my $i=0;$i < $upper;$i++) {
DEBUG $i;
}
sub get_log_fn
{
use File::Basename;
return sprintf "%s.log", basename( $0, '.pl' );
}