git-svn-id: http://svn.centreon.com/Plugins/Dev@2348 6bcd3966-0018-0410-8128-fd23d134de7e
This commit is contained in:
Mat Sugumaran 2007-05-22 12:49:37 +00:00
parent ab77bb8545
commit a09e206db1
3 changed files with 99 additions and 54 deletions

View File

@ -28,9 +28,16 @@ use strict;
use Net::SNMP qw(:snmp); use Net::SNMP qw(:snmp);
use FindBin; use FindBin;
use lib "$FindBin::Bin"; use lib "$FindBin::Bin";
use lib "@NAGIOS_PLUGINS@"; use lib "/srv/nagios/libexec";
use utils qw($TIMEOUT %ERRORS &print_revision &support); use utils qw($TIMEOUT %ERRORS &print_revision &support);
if (eval "require oreon" ) {
use oreon qw(get_parameters);
use vars qw($VERSION %oreon);
%oreon=get_parameters();
} else {
print "Unable to load oreon perl module\n";
exit $ERRORS{'UNKNOWN'};
}
use vars qw($PROGNAME); use vars qw($PROGNAME);
use Getopt::Long; use Getopt::Long;
use vars qw($opt_V $opt_h $opt_v $opt_C $opt_H $opt_D $snmp); use vars qw($opt_V $opt_h $opt_v $opt_C $opt_H $opt_D $snmp);
@ -61,13 +68,18 @@ if ($opt_h) {
exit $ERRORS{'OK'}; exit $ERRORS{'OK'};
} }
$opt_H = shift unless ($opt_H); if (!$opt_H) {
(print_usage() && exit $ERRORS{'OK'}) unless ($opt_H); print_usage();
exit $ERRORS{'OK'};
}
my $snmp = "1";
if ($opt_v && $opt_v =~ /(\d)/) {
$snmp = $opt_v;
}
($opt_v) || ($opt_v = shift) || ($opt_v = "2"); if (!$opt_C) {
$snmp = $1 if ($opt_v =~ /(\d)/); $opt_C = "public";
}
($opt_C) || ($opt_C = shift) || ($opt_C = "public");
my $name = $0; my $name = $0;
$name =~ s/\.pl.*//g; $name =~ s/\.pl.*//g;

View File

@ -28,12 +28,20 @@ use strict;
use Net::SNMP qw(:snmp oid_lex_sort); use Net::SNMP qw(:snmp oid_lex_sort);
use FindBin; use FindBin;
use lib "$FindBin::Bin"; use lib "$FindBin::Bin";
use lib "@NAGIOS_PLUGINS@"; use lib "/srv/nagios/libexec";
use utils qw($TIMEOUT %ERRORS &print_revision &support); use utils qw($TIMEOUT %ERRORS &print_revision &support);
if (eval "require oreon" ) {
use oreon qw(get_parameters);
use vars qw($VERSION %oreon);
%oreon=get_parameters();
} else {
print "Unable to load oreon perl module\n";
exit $ERRORS{'UNKNOWN'};
}
use vars qw($PROGNAME); use vars qw($PROGNAME);
use Getopt::Long; use Getopt::Long;
use vars qw($opt_V $opt_h $opt_v $opt_C $opt_p $opt_H $opt_D $opt_n $result @result %process_list %STATUS); use vars qw($opt_V $opt_h $opt_v $opt_C $opt_p $opt_H $opt_n $result @result %process_list %STATUS);
# Plugin var init # Plugin var init
@ -50,13 +58,10 @@ Getopt::Long::Configure('bundling');
GetOptions GetOptions
("h" => \$opt_h, "help" => \$opt_h, ("h" => \$opt_h, "help" => \$opt_h,
"V" => \$opt_V, "version" => \$opt_V, "V" => \$opt_V, "version" => \$opt_V,
"g" => \$opt_g, "rrdgraph" => \$opt_g,
"rrd_step=s" => \$opt_step, "f" => \$opt_f,
"n" => \$opt_n, "number" => \$opt_n, "n" => \$opt_n, "number" => \$opt_n,
"v=s" => \$opt_v, "snmp=s" => \$opt_v, "v=s" => \$opt_v, "snmp=s" => \$opt_v,
"C=s" => \$opt_C, "community=s" => \$opt_C, "C=s" => \$opt_C, "community=s" => \$opt_C,
"p=s" => \$opt_p, "process=s" => \$opt_p, "p=s" => \$opt_p, "process=s" => \$opt_p,
"S=s" => \$opt_S, "ServiceId=s" => \$opt_S,
"H=s" => \$opt_H, "hostname=s" => \$opt_H); "H=s" => \$opt_H, "hostname=s" => \$opt_H);
if ($opt_V) { if ($opt_V) {
@ -69,24 +74,32 @@ if ($opt_h) {
exit $ERRORS{'OK'}; exit $ERRORS{'OK'};
} }
$opt_H = shift unless ($opt_H); if (!$opt_H) {
(print_usage() && exit $ERRORS{'OK'}) unless ($opt_H); print_usage();
exit $ERRORS{'OK'};
($opt_v) || ($opt_v = shift) || ($opt_v = "1");
my $snmp = $1 if ($opt_v =~ /(\d)/);
($opt_C) || ($opt_C = shift) || ($opt_C = "public");
my $process = "";
if ($opt_p){
$process = $1 if ($opt_p =~ /([-.A-Za-z0-9]+)/);
} }
my $snmp = "1";
if ($opt_v && $opt_v =~ /(\d)/) {
$snmp = $opt_v;
}
if (!$opt_C) {
$opt_C = "public";
}
my $process;
if(!$opt_p) {
print_usage();
exit $ERRORS{'OK'};
}elsif ($opt_p !~ /([-.A-Za-z0-9]+)/){
print_usage();
exit $ERRORS{'OK'};
}
$process = $opt_p;
my $name = $0; my $name = $0;
$name =~ s/\.pl.*//g; $name =~ s/\.pl.*//g;
# Plugin snmp requests # Plugin snmp requests
my $OID_SW_RunName = $oreon{MIB2}{SW_RUNNAME}; my $OID_SW_RunName = $oreon{MIB2}{SW_RUNNAME};
my $OID_SW_RunIndex =$oreon{MIB2}{SW_RUNINDEX}; my $OID_SW_RunIndex =$oreon{MIB2}{SW_RUNINDEX};
my $OID_SW_RunStatus =$oreon{MIB2}{SW_RUNSTATUS}; my $OID_SW_RunStatus =$oreon{MIB2}{SW_RUNSTATUS};
@ -127,7 +140,6 @@ if (!($opt_n))
exit $ERRORS{'UNKNOWN'}; exit $ERRORS{'UNKNOWN'};
} }
$proc_run = $result->{$OID_SW_RunStatus . "." . $process_list{$process} }; $proc_run = $result->{$OID_SW_RunStatus . "." . $process_list{$process} };
print $proc_run;
} }
} }

View File

@ -28,9 +28,16 @@ use strict;
use Net::SNMP qw(:snmp oid_lex_sort); use Net::SNMP qw(:snmp oid_lex_sort);
use FindBin; use FindBin;
use lib "$FindBin::Bin"; use lib "$FindBin::Bin";
use lib "@NAGIOS_PLUGINS@"; use lib "/srv/nagios/libexec";
use utils qw($TIMEOUT %ERRORS &print_revision &support); use utils qw($TIMEOUT %ERRORS &print_revision &support);
if (eval "require oreon" ) {
use oreon qw(get_parameters);
use vars qw(%oreon);
%oreon=get_parameters();
} else {
print "Unable to load oreon perl module\n";
exit $ERRORS{'UNKNOWN'};
}
use vars qw($PROGNAME); use vars qw($PROGNAME);
use Getopt::Long; use Getopt::Long;
use vars qw($opt_V $opt_h $opt_v $opt_C $opt_b $opt_H $opt_D $opt_i $opt_n $opt_w $opt_c $opt_s $opt_T); use vars qw($opt_V $opt_h $opt_v $opt_C $opt_b $opt_H $opt_D $opt_i $opt_n $opt_w $opt_c $opt_s $opt_T);
@ -72,29 +79,43 @@ if ($opt_h) {
##### Verify Options ##### Verify Options
## ##
$opt_H = shift unless ($opt_H); if (!$opt_H) {
(print_usage() && exit $ERRORS{'OK'}) unless ($opt_H); print_usage();
exit $ERRORS{'OK'};
($opt_v) || ($opt_v = shift) || ($opt_v = "1"); }
my $snmp = $1 if ($opt_v =~ /(\d)/); my $snmp = "1";
if ($opt_v && $opt_v =~ /(\d)/) {
$snmp = $opt_v;
}
if ($opt_n && !$opt_i) { if ($opt_n && !$opt_i) {
print "Option -n (--name) need option -i (--interface)\n"; print "Option -n (--name) need option -i (--interface)\n";
exit $ERRORS{'UNKNOWN'}; exit $ERRORS{'UNKNOWN'};
} }
($opt_C) || ($opt_C = shift) || ($opt_C = "public"); if (!$opt_C) {
($opt_i) || ($opt_i = shift) || ($opt_i = 2); $opt_C = "public";
}
($opt_b) || ($opt_b = shift) || ($opt_b = 95); if (!$opt_i) {
my $bps = $1 if ($opt_b =~ /([0-9]+)/); $opt_i = 2;
}
($opt_c) || ($opt_c = shift) || ($opt_c = 95); if (!$opt_b) {
my $critical = $1 if ($opt_c =~ /([0-9]+)/); $opt_b = 95;
}
($opt_w) || ($opt_w = shift) || ($opt_w = 80);
my $warning = $1 if ($opt_w =~ /([0-9]+)/);
if ($opt_b =~ /([0-9]+)/) {
my $bps = $1;
}
my $critical = 95;
if ($opt_c && $opt_c =~ /[0-9]+/) {
$critical = $opt_c;
}
my $warning = 80;
if ($opt_w && $opt_w =~ /[0-9]+/) {
$warning = $opt_w;
}
my $interface = 0; my $interface = 0;
if ($opt_i =~ /([0-9]+)/ && !$opt_n){ if ($opt_i =~ /([0-9]+)/ && !$opt_n){
$interface = $1; $interface = $1;
@ -217,8 +238,8 @@ $last_out_bits = 0;
my $flg_created = 0; my $flg_created = 0;
if (-e "/tmp/traffic_if".$interface."_".$opt_H) { if (-e "/tmp/oreon_traffic_if".$interface."_".$opt_H) {
open(FILE,"<"."/tmp/traffic_if".$interface."_".$opt_H); open(FILE,"<"."/tmp/oreon_traffic_if".$interface."_".$opt_H);
while($row = <FILE>){ while($row = <FILE>){
@last_values = split(":",$row); @last_values = split(":",$row);
$last_check_time = $last_values[0]; $last_check_time = $last_values[0];
@ -233,8 +254,8 @@ if (-e "/tmp/traffic_if".$interface."_".$opt_H) {
$update_time = time(); $update_time = time();
unless (open(FILE,">"."/tmp/traffic_if".$interface."_".$opt_H)){ unless (open(FILE,">"."/tmp/oreon_traffic_if".$interface."_".$opt_H)){
print "Unknown - /tmp/traffic_if".$interface."_".$opt_H. " !\n"; print "Unknown - /tmp/oreon_traffic_if".$interface."_".$opt_H. " !\n";
exit $ERRORS{"UNKNOWN"}; exit $ERRORS{"UNKNOWN"};
} }
print FILE "$update_time:$in_bits:$out_bits"; print FILE "$update_time:$in_bits:$out_bits";