bug fix
git-svn-id: http://svn.centreon.com/Plugins/Dev@2348 6bcd3966-0018-0410-8128-fd23d134de7e
This commit is contained in:
parent
ab77bb8545
commit
a09e206db1
|
@ -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;
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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";
|
||||||
|
|
Loading…
Reference in New Issue