--- sap.monitor 2002/07/10 12:30:23 1.4 +++ sap.monitor 2002/07/22 12:26:06 1.7 @@ -14,9 +14,11 @@ # change paths here if you want to my $CONFIG = "/usr/local/etc/sap-mon.conf"; my $SAPINFO = "/usr/local/bin/sapinfo"; +# number of tries to repeat sapinfo if it fails first time +my $repeat = 3; my %opts; -getopt('h:s:', \%opts); +getopt('h:s:H:S:', \%opts); my @config; open(C, $CONFIG) || die "sap-mon.conf: $!"; @@ -36,16 +38,28 @@ chomp; s/#.+$//g; # nuke comments s/^\s+$//g; # remove empty lines - my ($ashost,$sysnr) = split(/\t+/,$_,2); + my ($ashost,$sysnr,undef) = split(/\s+/,$_,3); if ($ashost && $ashost ne "" && $sysnr && $sysnr ne "" && (($opts{h} && $ashost =~ m/$opts{h}/) || not $opts{h}) && (($opts{s} && $sysnr =~ m/$opts{s}/) || not $opts{s}) && (($opts{H} && $ashost !~ m/$opts{H}/) || not $opts{H}) && (($opts{S} && $sysnr !~ m/$opts{S}/) || not $opts{S}) ) { - my $output = `$SAPINFO trace=0 ashost=$ashost sysnr=$sysnr`; - $output =~ m/System ID\s+(\w+)/; - my $sys_id = $1 || ""; - if ($? != 0) { + my $ret = 1; + my $loop = 0; + my $output; + my $sys_id; + for(my $i=0; $i<$repeat; $i++) { + $output = `$SAPINFO trace=0 ashost=$ashost sysnr=$sysnr`; + undef $sys_id; + if ($output =~ m/System\s+ID\s+(\w+)/i) { + $sys_id = $1; + last; + } +# print "$loop: $ashost $sysnr $ret\n"; + $loop++; + sleep 5; + } + if (! $sys_id) { push @failed, "$ashost ($sysnr)"; $fail_msg .= $output; } else { @@ -57,12 +71,12 @@ my $exit = 0; if (@failed) { - print "FAILED HOSTS: ",join(", ",@failed),"\n\n"; + print join(", ",@failed)," FAILED\n\n"; print "$fail_msg\n"; $exit = 1; } -print "CHECKED HOSTS (which are OK): ",join(", ",@ok),"\n\n"; +print "ALL OK\nCHECKED HOSTS (which are OK): ",join(", ",@ok),"\n\n"; rmdir "/tmp/sap$$" || die "can't rmdir in /tmp/sap$$: $!";