![]() ![]() |
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 librariesuse strict;use warnings;use diagnostics;# include HotSaNIC librariesuse 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=CLOSINGmy @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;