--- parse_iptraf.pl 2002/05/20 16:31:01 1.3 +++ parse_iptraf.pl 2002/05/22 07:11:08 1.5 @@ -2,22 +2,40 @@ # based on work of Eric Wong # available at http://www.taedium.net/rrd-iptraf/ [iptraf.txt] +# +# Dobrica Pavlinusic use strict; use warnings; -use Time::Local; - my @PORTS = qw ( TCP/22 TCP/25 TCP/20 TCP/21 UDP/53 TCP/80 TCP/110 TCP/113 TCP/119 UDP/137 UDP/138 TCP/210 TCP/443 UDP/514 ); -#my $log = '/var/log/iptraf/tcp_udp_services-eth1.log'; -my $log = '/home/dpavlin/iptraf/tcp_udp_services-eth1.log'; +my $log = '/var/log/iptraf/tcp_udp_services-eth1.log'; +#my $log = '/home/dpavlin/iptraf/tcp_udp_services-eth1.log'; + +$log = $ARGV[0] if ($ARGV[0] && -r $ARGV[0]); open(LOG,$log) || die "Can't open logfile '$log': $!"; +my $delta="/var/tmp/"; +my $tmp_log=$log; +$tmp_log=~s/\W/_/g; +$delta.=$tmp_log.".offset"; + +if (-e $delta) { + open(D,$delta) || die "can't open delta file '$delta' for log '$log': $!"; + my $offset=; + chomp $offset; + close(D); + my $log_size = -s $log; + if ($offset <= $log_size) { + seek(LOG,$offset,0); + } +} + my %hash; while () { @@ -34,10 +52,14 @@ } } +open(D,"> $delta") || die "can't open delta file '$delta' for log '$log': $!"; +print D tell(LOG); +close(D); + close(LOG); foreach my $port (@PORTS) { - print @{$hash{$port}}[0] || 0,"\n",@{$hash{$port}}[1] || 0,"\n"; + print @{$hash{$port}}[0] || "U","\n",@{$hash{$port}}[1] || "U","\n"; delete $hash{$port}; } @@ -47,4 +69,7 @@ $sum_in+=@{$hash{$port}}[0]; $sum_out+=@{$hash{$port}}[1]; } + +$sum_in = "U" if ($sum_in == 0); +$sum_out = "U" if ($sum_out == 0); print "$sum_in\n$sum_out\n";