hotsanic |
Subversion Repositories: |
Compare with Previous - Blame - Download
#!/usr/bin/env perl
# $Id: diagrams.pl,v 1.10 2004/05/23 23:53:39 bernisys Exp $
# include PERL libraries
use strict;
use warnings;
use diagnostics;
# include HotSaNIC libraries
use lib "../../lib";
use lib "./platform";
use HotSaNICparser;
use HotSaNICdiagram;
use common;
(my $VERSION = '$Revision: 1.10 $') =~ s/.*(\d+\.\d+).*/$1/;
(my $IDENTIFIER = '$Id: diagrams.pl,v 1.10 2004/05/23 23:53:39 bernisys Exp $') =~ s/.*,v (.*) \$/$1/;
# read all settings
#
my $MODNAME=HotSaNICparser::get_module_name();
my %CONFIG=HotSaNICparser::get_config("../..");
my %MODULECONFIG=HotSaNICmod::common::configure();
my $IMGFMT=lc $CONFIG{"IMAGEFORMAT"};
my $OUTDIR=$CONFIG{"WEBDIR"}."/".lc $MODNAME;
if ( ! -e $OUTDIR ) { mkdir $OUTDIR,0755; }
my ($FORCE,$DEBUGLEVEL,%PLOT)=HotSaNICdiagram::check_args(@ARGV);
my @OPTIONS=HotSaNICdiagram::get_common_options(%MODULECONFIG,%CONFIG);
# handle module-specific stuff
#
my $LEGEND="connections";
push @OPTIONS,(
"-v",$LEGEND, # Y-legend
"--alt-autoscale-max"); # alternate scaling
# closing connection: ESTA -> FW1 -> CLSWT -> FW2 -> LACK -> TWT -> CLOSE
# establishing connection: CLOSE -> LSTN -> SYNS -> SYNR -> ESTA
# CLOSING: both sides shutdown, but data still to be sent (kind of an error state)
# generate diagrams
#
foreach my $dev ("connections") {
my $name=$dev;
my $DB_FILE="./rrd/$dev.rrd";
print "creating images for $dev netstats...\n";
# if database exists, create images...
if ( -e $DB_FILE) {
foreach my $range ("1h","6h","1day","1week","1month","1year") {
my ($descr,$file,$build,$fullrange,$DATESTRING)=HotSaNICdiagram::get_diagram_properties($range);
my $FILENAME="$OUTDIR/$name-$file.$IMGFMT";
# 01=ESTABLISHED 02=SYN_SENT 03=SYN_RECV 04=FIN_WAIT1 05=FIN_WAIT2
# 06=TIME_WAIT 07=CLOSE 08=CLOSE_WAIT 09=LAST_ACK 0A=LISTEN 0B=CLOSING
my @EXTOPTIONS=("-s","-$range", "--title", "socket stats for $name - last $descr ($DATESTRING)");
my @COMMANDS;
my $legends="min avg max";
if ($range eq "1h") { $legends="min avg max cur"; }
if ($^O =~ /linux/) {
@COMMANDS=("DEF:aunkn=$DB_FILE:unknown:AVERAGE",
"DEF:aesta=$DB_FILE:established:AVERAGE",
"DEF:asyns=$DB_FILE:synsent:AVERAGE",
"DEF:asynr=$DB_FILE:synrecv:AVERAGE",
"DEF:afwt1=$DB_FILE:finwait1:AVERAGE",
"DEF:afwt2=$DB_FILE:finwait2:AVERAGE",
"DEF:atmwt=$DB_FILE:timewait:AVERAGE",
"DEF:aclse=$DB_FILE:close:AVERAGE",
"DEF:aclwt=$DB_FILE:closewait:AVERAGE",
"DEF:alack=$DB_FILE:lastack:AVERAGE",
"DEF:alstn=$DB_FILE:listen:AVERAGE",
"DEF:acsng=$DB_FILE:closing:AVERAGE",
"DEF:iunkn=$DB_FILE:unknown:MIN",
"DEF:iesta=$DB_FILE:established:MIN",
"DEF:isyns=$DB_FILE:synsent:MIN",
"DEF:isynr=$DB_FILE:synrecv:MIN",
"DEF:ifwt1=$DB_FILE:finwait1:MIN",
"DEF:ifwt2=$DB_FILE:finwait2:MIN",
"DEF:itmwt=$DB_FILE:timewait:MIN",
"DEF:iclse=$DB_FILE:close:MIN",
"DEF:iclwt=$DB_FILE:closewait:MIN",
"DEF:ilack=$DB_FILE:lastack:MIN",
"DEF:ilstn=$DB_FILE:listen:MIN",
"DEF:icsng=$DB_FILE:closing:MIN",
"DEF:xunkn=$DB_FILE:unknown:MAX",
"DEF:xesta=$DB_FILE:established:MAX",
"DEF:xsyns=$DB_FILE:synsent:MAX",
"DEF:xsynr=$DB_FILE:synrecv:MAX",
"DEF:xfwt1=$DB_FILE:finwait1:MAX",
"DEF:xfwt2=$DB_FILE:finwait2:MAX",
"DEF:xtmwt=$DB_FILE:timewait:MAX",
"DEF:xclse=$DB_FILE:close:MAX",
"DEF:xclwt=$DB_FILE:closewait:MAX",
"DEF:xlack=$DB_FILE:lastack:MAX",
"DEF:xlstn=$DB_FILE:listen:MAX",
"DEF:xcsng=$DB_FILE:closing:MAX",
HotSaNICdiagram::insert_data("AREA" ,"alstn ilstn alstn xlstn alstn",$MODULECONFIG{COLOR_LISTEN} ,"listen ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","asyns isyns asyns xsyns asyns",$MODULECONFIG{COLOR_SYNSENT} ,"syn sent ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","asynr isynr asynr xsynr asynr",$MODULECONFIG{COLOR_SYNRECV} ,"syn received",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","aesta iesta aesta xesta aesta",$MODULECONFIG{COLOR_ESTABLISHED},"established ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","afwt1 ifwt1 afwt1 xfwt1 afwt1",$MODULECONFIG{COLOR_FINWAIT1} ,"fin wait 1 ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","aclwt iclwt aclwt xclwt aclwt",$MODULECONFIG{COLOR_CLOSEWAIT} ,"close wait ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","afwt2 ifwt2 afwt2 xfwt2 afwt2",$MODULECONFIG{COLOR_FINWAIT2} ,"fin wait 2 ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","alack ilack alack xlack alack",$MODULECONFIG{COLOR_LASTACK} ,"last ack ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","atmwt itmwt atmwt xtmwt atmwt",$MODULECONFIG{COLOR_TIMEWAIT} ,"time wait ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","acsng icsng acsng xcsng acsng",$MODULECONFIG{COLOR_CLOSING} ,"closing ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","aclse iclse aclse xclse aclse",$MODULECONFIG{COLOR_CLOSE} ,"close ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_data("STACK","aunkn iunkn aunkn xunkn aunkn",$MODULECONFIG{COLOR_UNKNOWN} ,"unknown ",$legends,$LEGEND,1),
HotSaNICdiagram::insert_lines(%MODULECONFIG));
}
my %CONF=(RANGE=>$descr,FILENAME=>"$OUTDIR/$name-$file",FORMAT=>$IMGFMT,INTERVAL=>$build,FORCE=>$FORCE,OPTIONS=>[@OPTIONS,@EXTOPTIONS,@COMMANDS],DEBUGLEVEL=>$DEBUGLEVEL,MODNAME=>$MODNAME);
HotSaNICdiagram::graph(%CONF);
}
print "\n";
}
else { print " No database \"$DB_FILE\" found\n Please check if the daemon is running.\n\n"; }
}
exit 0;