my $graphid = 1;
my $NODATA = '<div class="flotr-graph"><blockquote><b>NO DATASET</b></blockquote></div>';
my $MAX_QUERY_LENGTH = 20480;
+my $terminate = 0;
my $pgbadger_logo =
'<img src="">';
my %current_sessions = ();
my $incr_date = '';
my $last_incr_date = '';
-my $anonymize = 0;
+my $anonymize = 0;
+my $noclean = 0;
my $NUMPROGRESS = 10000;
my @DIMENSIONS = (800, 300);
'ssh-option=s' => \$ssh_options,
'ssh-user=s' => \$ssh_user,
'ssh-timeout=i' => \$ssh_timeout,
- 'anonymize!' => \$anonymize,
+ 'anonymize!' => \$anonymize,
+ 'noclean!' => \$noclean,
);
die "FATAL: use pgbadger --help\n" if (not $result);
$tmp_last_parsed = 'tmp_' . basename($last_parsed) if ($last_parsed);
$tmp_last_parsed = "$TMP_DIR/$tmp_last_parsed";
+# Clean the incremental directory if the feature is not disabled
+if (!$noclean && $saved_last_line{datetime}) {
+
+ # Search the current week following the last parse date
+ $saved_last_line{datetime} =~ /^(\d+)\-(\d+)\-(\d+) /;
+ my $last_year = $1;
+ my $last_month = $2;
+ my $last_day = $3;
+ # Get the week number following the date
+ my $wn = &get_week_number($last_year, $last_month, $last_day);
+ # Get the deys of the current week where binary files must be preserved
+ my @wdays = &get_wdays_per_month($wn - 1, "$last_year-$last_month");
+ # Find obsolete dir days that shoud be cleaned
+ unless(opendir(DIR, "$outdir")) {
+ die "Error: can't opendir $outdir: $!";
+ }
+ my @dyears = grep { $_ =~ /^\d+$/ } readdir(DIR);
+ closedir DIR;
+ my @obsolete_days = ();
+ foreach my $y (sort { $a <=> $b } @dyears) {
+ unless(opendir(DIR, "$outdir/$y")) {
+ die "Error: can't opendir $outdir/$y: $!";
+ }
+ my @dmonths = grep { $_ =~ /^\d+$/ } readdir(DIR);
+ closedir DIR;
+ foreach my $m (sort { $a <=> $b } @dmonths) {
+ unless(opendir(DIR, "$outdir/$y/$m")) {
+ die "Error: can't opendir $outdir/$y/$m: $!";
+ }
+ my @ddays = grep { $_ =~ /^\d+$/ } readdir(DIR);
+ closedir DIR;
+ foreach my $d (sort { $a <=> $b } @ddays) {
+ if ("$y-$m-$d" lt $wdays[0]) {
+ push(@obsolete_days, "$outdir/$y/$m/$d");
+ }
+ }
+ }
+ }
+ foreach my $p (@obsolete_days) {
+ unless(opendir(DIR, "$p")) {
+ die "Error: can't opendir $p: $!";
+ }
+ my @hfiles = grep { $_ =~ /\.(html|txt|tsung|json)$/i } readdir(DIR);
+ next if ($#hfiles == -1); # do not remove files if report file has not been generated
+ seekdir(DIR, 0);
+ my @bfiles = grep { $_ =~ /\.bin$/i } readdir(DIR);
+ closedir DIR;
+ foreach my $f (@bfiles) {
+ &logmsg('DEBUG', "Removing obsolete binary file: $p/$f");
+ unlink("$p/$f");
+ }
+ }
+}
# Main loop reading log files
my $global_totalsize = 0;
foreach my $f (@tempfiles) {
next if (!-e "$f->[1]" || -z "$f->[1]");
my $fht = new IO::File;
- $fht->open("< $f->[1]") or die "FATAL: can't open file $f->[1], $!\n";
+ $fht->open("< $f->[1]") or die "FATAL: can't open temp file $f->[1], $!\n";
&load_stats($fht);
$fht->close();
}
}
}
+exit 0 if ($terminate);
+
my $t1 = Benchmark->new;
my $td = timediff($t1, $t0);
&logmsg('DEBUG', "the log statistics gathering took:" . timestr($td));
foreach $incr_date (@wdays) {
my $bpath = $incr_date;
$bpath =~ s/\-/\//g;
- $incr_date =~ /^(\d+)-(\d+)\-(\d+)$/;
+ $incr_date =~ /^(\d+)\-(\d+)\-(\d+)$/;
$wdir = "$1/week-$wn";
# Load all data gathered by all the differents processes
&logmsg('DEBUG', "Starting to parse remote log file: $remote_host:$logfile");
}
- my $terminate = 0;
- local $SIG{INT} = sub { $terminate = 1 };
- local $SIG{TERM} = sub { $terminate = 1 };
+ local $SIG{INT} = sub { print STDERR "Received SIGINT abort parsing...\n"; $terminate = 1; };
+ local $SIG{TERM} = sub { print STDERR "Received SIGTERM abort parsing...\n"; $terminate = 1 };
my $curdate = localtime(time);
}
close $lfile;
+ # Inform the parent that it should stop parsing other files
+ if ($terminate) {
+ kill(12, $parent_pid);
+ return $terminate;
+ }
+
# Get stats from all pending temporary storage
foreach my $pid (sort {$cur_info{$a}{date} <=> $cur_info{$b}{date}} keys %cur_info) {
# Stores last query information
return @retdays;
}
-# Returns all days following the week number
-sub get_wdays_per_year
-{
- my $y = shift;
- my %result = ();
-
- foreach my $m ("01" .. "12") {
- foreach my $day ("01" .. "31") {
- # Check if the date is valid first
- my $datefmt = POSIX::strftime("%Y-%m-%d", 1, 1, 1, $day, $m - 1, $y - 1900);
- if ($datefmt ne "$y-$m-$day") {
- next;
- }
- my $weekNumber = POSIX::strftime("%U", 1, 1, 1, $day, $m - 1, $y - 1900);
- push(@{$result{$weekNumber}}, "$y-$m-$day");
- }
- }
-
- return %result;
-}
-
sub IsLeapYear
{
return ((($_[0] & 3) == 0) && (($_[0] % 100 != 0) || ($_[0] % 400 == 0)));