mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-26 15:14:16 +02:00
improve cisco ucs plugin refs #5168
This commit is contained in:
parent
c76d5f9487
commit
7ed547e72b
99
hardware/server/cisco/ucs/mode/components/fex.pm
Normal file
99
hardware/server/cisco/ucs/mode/components/fex.pm
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
################################################################################
|
||||||
|
# Copyright 2005-2013 MERETHIS
|
||||||
|
# Centreon is developped by : Julien Mathis and Romain Le Merlus under
|
||||||
|
# GPL Licence 2.0.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify it under
|
||||||
|
# the terms of the GNU General Public License as published by the Free Software
|
||||||
|
# Foundation ; either version 2 of the License.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||||
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||||
|
# PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License along with
|
||||||
|
# this program; if not, see <http://www.gnu.org/licenses>.
|
||||||
|
#
|
||||||
|
# Linking this program statically or dynamically with other modules is making a
|
||||||
|
# combined work based on this program. Thus, the terms and conditions of the GNU
|
||||||
|
# General Public License cover the whole combination.
|
||||||
|
#
|
||||||
|
# As a special exception, the copyright holders of this program give MERETHIS
|
||||||
|
# permission to link this program with independent modules to produce an executable,
|
||||||
|
# regardless of the license terms of these independent modules, and to copy and
|
||||||
|
# distribute the resulting executable under terms of MERETHIS choice, provided that
|
||||||
|
# MERETHIS also meet, for each linked independent module, the terms and conditions
|
||||||
|
# of the license of that module. An independent module is a module which is not
|
||||||
|
# derived from this program. If you modify this program, you may extend this
|
||||||
|
# exception to your version of the program, but you are not obliged to do so. If you
|
||||||
|
# do not wish to do so, delete this exception statement from your version.
|
||||||
|
#
|
||||||
|
# For more information : contact@centreon.com
|
||||||
|
# Authors : Quentin Garnier <qgarnier@merethis.com>
|
||||||
|
#
|
||||||
|
####################################################################################
|
||||||
|
|
||||||
|
package hardware::server::cisco::ucs::mode::components::fex;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use hardware::server::cisco::ucs::mode::components::resources qw($thresholds);
|
||||||
|
|
||||||
|
sub check {
|
||||||
|
my ($self) = @_;
|
||||||
|
|
||||||
|
# In MIB 'CISCO-UNIFIED-COMPUTING-EQUIPMENT-MIB'
|
||||||
|
$self->{output}->output_add(long_msg => "Checking fabric extenders");
|
||||||
|
$self->{components}->{fex} = {name => 'fabric extenders', total => 0, skip => 0};
|
||||||
|
return if ($self->check_exclude(section => 'fex'));
|
||||||
|
|
||||||
|
my $oid_cucsEquipmentFexDn = '.1.3.6.1.4.1.9.9.719.1.15.19.1.2';
|
||||||
|
my $oid_cucsEquipmentFexOperState = '.1.3.6.1.4.1.9.9.719.1.15.19.1.21';
|
||||||
|
my $oid_cucsEquipmentFexPresence = '.1.3.6.1.4.1.9.9.719.1.15.19.1.24';
|
||||||
|
|
||||||
|
my $result = $self->{snmp}->get_multiple_table(oids => [
|
||||||
|
{ oid => $oid_cucsEquipmentFexDn },
|
||||||
|
{ oid => $oid_cucsEquipmentFexOperState },
|
||||||
|
{ oid => $oid_cucsEquipmentFexPresence },
|
||||||
|
]
|
||||||
|
);
|
||||||
|
foreach my $key ($self->{snmp}->oid_lex_sort(keys %{$result->{$oid_cucsEquipmentFexDn}})) {
|
||||||
|
# index
|
||||||
|
$key =~ /\.(\d+)$/;
|
||||||
|
my $fex_index = $1;
|
||||||
|
my $fex_dn = $result->{$oid_cucsEquipmentFexDn}->{$oid_cucsEquipmentFexDn . '.' . $fex_index};
|
||||||
|
my $fex_operstate = defined($result->{$oid_cucsEquipmentFexOperState}->{$oid_cucsEquipmentFexOperState . '.' . $fex_index}) ?
|
||||||
|
$result->{$oid_cucsEquipmentFexOperState}->{$oid_cucsEquipmentFexOperState . '.' . $fex_index} : 0; # unknown
|
||||||
|
my $fex_presence = defined($result->{$oid_cucsEquipmentFexPresence}->{$oid_cucsEquipmentFexPresence . '.' . $fex_index}) ?
|
||||||
|
$result->{$oid_cucsEquipmentFexPresence}->{$oid_cucsEquipmentFexPresence . '.' . $fex_index} : 0;
|
||||||
|
|
||||||
|
next if ($self->absent_problem(section => 'fex', instance => $fex_dn));
|
||||||
|
next if ($self->check_exclude(section => 'fex', instance => $fex_dn));
|
||||||
|
|
||||||
|
my $exit = $self->get_severity(section => 'fex', threshold => 'presence', value => $fex_presence);
|
||||||
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
|
$self->{output}->output_add(severity => $exit,
|
||||||
|
short_msg => sprintf("Fabric extender '%s' presence is: '%s'",
|
||||||
|
$fex_dn, ${$thresholds->{presence}->{$fex_presence}}[0])
|
||||||
|
);
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{components}->{fex}->{total}++;
|
||||||
|
|
||||||
|
$self->{output}->output_add(long_msg => sprintf("Fabric extender '%s' state is '%s' [presence: %s].",
|
||||||
|
$fex_dn, ${$thresholds->{operability}->{$fex_operstate}}[0],
|
||||||
|
${$thresholds->{presence}->{$fex_presence}}[0]
|
||||||
|
));
|
||||||
|
$exit = $self->get_severity(section => 'fex', threshold => 'operability', value => $fex_operstate);
|
||||||
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
|
$self->{output}->output_add(severity => $exit,
|
||||||
|
short_msg => sprintf("Fabric extender '%s' state is '%s'.",
|
||||||
|
$fex_dn, ${$thresholds->{operability}->{$fex_operstate}}[0]
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
@ -45,6 +45,7 @@ use hardware::server::cisco::ucs::mode::components::psu;
|
|||||||
use hardware::server::cisco::ucs::mode::components::iocard;
|
use hardware::server::cisco::ucs::mode::components::iocard;
|
||||||
use hardware::server::cisco::ucs::mode::components::chassis;
|
use hardware::server::cisco::ucs::mode::components::chassis;
|
||||||
use hardware::server::cisco::ucs::mode::components::blade;
|
use hardware::server::cisco::ucs::mode::components::blade;
|
||||||
|
use hardware::server::cisco::ucs::mode::components::fex;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
@ -102,6 +103,7 @@ sub global {
|
|||||||
hardware::server::cisco::ucs::mode::components::iocard::check($self);
|
hardware::server::cisco::ucs::mode::components::iocard::check($self);
|
||||||
hardware::server::cisco::ucs::mode::components::chassis::check($self);
|
hardware::server::cisco::ucs::mode::components::chassis::check($self);
|
||||||
hardware::server::cisco::ucs::mode::components::blade::check($self);
|
hardware::server::cisco::ucs::mode::components::blade::check($self);
|
||||||
|
hardware::server::cisco::ucs::mode::components::fex::check($self);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub component {
|
sub component {
|
||||||
@ -117,6 +119,8 @@ sub component {
|
|||||||
hardware::server::cisco::ucs::mode::components::chassis::check($self);
|
hardware::server::cisco::ucs::mode::components::chassis::check($self);
|
||||||
} elsif ($self->{option_results}->{component} eq 'blade') {
|
} elsif ($self->{option_results}->{component} eq 'blade') {
|
||||||
hardware::server::cisco::ucs::mode::components::blade::check($self);
|
hardware::server::cisco::ucs::mode::components::blade::check($self);
|
||||||
|
} elsif ($self->{option_results}->{component} eq 'fex') {
|
||||||
|
hardware::server::cisco::ucs::mode::components::fex::check($self);
|
||||||
} else {
|
} else {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong option. Cannot find component '" . $self->{option_results}->{component} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong option. Cannot find component '" . $self->{option_results}->{component} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
@ -211,14 +215,14 @@ __END__
|
|||||||
|
|
||||||
=head1 MODE
|
=head1 MODE
|
||||||
|
|
||||||
Check Hardware (Fans, Power supplies, chassis, io cards, blades).
|
Check Hardware (Fans, Power supplies, chassis, io cards, blades, fabric extenders).
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--component>
|
=item B<--component>
|
||||||
|
|
||||||
Which component to check (Default: 'all').
|
Which component to check (Default: 'all').
|
||||||
Can be: 'fan', 'psu', 'chassis', 'iocard', 'blade'
|
Can be: 'fan', 'psu', 'chassis', 'iocard', 'blade', 'fex'
|
||||||
|
|
||||||
=item B<--exclude>
|
=item B<--exclude>
|
||||||
|
|
||||||
|
162
hardware/server/cisco/ucs/mode/serviceprofile.pm
Normal file
162
hardware/server/cisco/ucs/mode/serviceprofile.pm
Normal file
@ -0,0 +1,162 @@
|
|||||||
|
################################################################################
|
||||||
|
# Copyright 2005-2013 MERETHIS
|
||||||
|
# Centreon is developped by : Julien Mathis and Romain Le Merlus under
|
||||||
|
# GPL Licence 2.0.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify it under
|
||||||
|
# the terms of the GNU General Public License as published by the Free Software
|
||||||
|
# Foundation ; either version 2 of the License.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||||
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||||
|
# PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License along with
|
||||||
|
# this program; if not, see <http://www.gnu.org/licenses>.
|
||||||
|
#
|
||||||
|
# Linking this program statically or dynamically with other modules is making a
|
||||||
|
# combined work based on this program. Thus, the terms and conditions of the GNU
|
||||||
|
# General Public License cover the whole combination.
|
||||||
|
#
|
||||||
|
# As a special exception, the copyright holders of this program give MERETHIS
|
||||||
|
# permission to link this program with independent modules to produce an executable,
|
||||||
|
# regardless of the license terms of these independent modules, and to copy and
|
||||||
|
# distribute the resulting executable under terms of MERETHIS choice, provided that
|
||||||
|
# MERETHIS also meet, for each linked independent module, the terms and conditions
|
||||||
|
# of the license of that module. An independent module is a module which is not
|
||||||
|
# derived from this program. If you modify this program, you may extend this
|
||||||
|
# exception to your version of the program, but you are not obliged to do so. If you
|
||||||
|
# do not wish to do so, delete this exception statement from your version.
|
||||||
|
#
|
||||||
|
# For more information : contact@centreon.com
|
||||||
|
# Authors : Quentin Garnier <qgarnier@merethis.com>
|
||||||
|
#
|
||||||
|
####################################################################################
|
||||||
|
|
||||||
|
package hardware::server::cisco::ucs::mode::serviceprofile;
|
||||||
|
|
||||||
|
use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
my %error_status = (
|
||||||
|
1 => ["online", 'OK'],
|
||||||
|
2 => ["offline", 'CRITICAL'],
|
||||||
|
);
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ($class, %options) = @_;
|
||||||
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
|
bless $self, $class;
|
||||||
|
|
||||||
|
$self->{version} = '1.0';
|
||||||
|
$options{options}->add_options(arguments =>
|
||||||
|
{
|
||||||
|
"warning:s" => { name => 'warning' },
|
||||||
|
"critical:s" => { name => 'critical' },
|
||||||
|
"skip" => { name => 'skip' },
|
||||||
|
});
|
||||||
|
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub check_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub run {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
# $options{snmp} = snmp object
|
||||||
|
$self->{snmp} = $options{snmp};
|
||||||
|
|
||||||
|
my $oid_cucsLsBindingDn = '.1.3.6.1.4.1.9.9.719.1.26.2.1.2';
|
||||||
|
my $oid_cucsLsBindingOperState = '.1.3.6.1.4.1.9.9.719.1.26.2.1.10';
|
||||||
|
|
||||||
|
my $result = $self->{snmp}->get_multiple_table(oids => [
|
||||||
|
{ oid => $oid_cucsLsBindingDn },
|
||||||
|
{ oid => $oid_cucsLsBindingOperState },
|
||||||
|
],
|
||||||
|
nothing_quit => 1
|
||||||
|
);
|
||||||
|
|
||||||
|
my $ls_online = 0;
|
||||||
|
my $ls_offline = 0;
|
||||||
|
|
||||||
|
foreach my $key ($self->{snmp}->oid_lex_sort(keys %{$result->{$oid_cucsLsBindingDn}})) {
|
||||||
|
# index
|
||||||
|
$key =~ /\.(\d+)$/;
|
||||||
|
my $ls_index = $1;
|
||||||
|
my $ls_name = $result->{$oid_cucsLsBindingDn}->{$oid_cucsLsBindingDn . '.' . $ls_index};
|
||||||
|
my $ls_operstate = $result->{$oid_cucsLsBindingOperState}->{$oid_cucsLsBindingOperState . '.' . $ls_index};
|
||||||
|
|
||||||
|
if ($ls_operstate == 1) {
|
||||||
|
$ls_online++;
|
||||||
|
} else {
|
||||||
|
$ls_offline++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($ls_operstate == 2 && defined($self->{option_results}->{skip})) {
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
if ($ls_operstate != 1) {
|
||||||
|
$self->{output}->output_add(severity => ${$error_status{$ls_operstate}}[1],
|
||||||
|
short_msg => sprintf("Service profile '%s' is %s", $ls_name, ${$error_status{$ls_operstate}}[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
my $ls_total = $ls_online + $ls_offline;
|
||||||
|
my $exit = $self->{perfdata}->threshold_check(value => $ls_online, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
|
$self->{output}->output_add(severity => $exit,
|
||||||
|
short_msg => sprintf("%d service profiles online", $ls_online));
|
||||||
|
|
||||||
|
$self->{output}->perfdata_add(label => "sp_online",
|
||||||
|
value => $ls_online,
|
||||||
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
||||||
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
||||||
|
min => 0, max => $ls_total);
|
||||||
|
|
||||||
|
$self->{output}->perfdata_add(label => "sp_offline",
|
||||||
|
value => $ls_offline,
|
||||||
|
min => 0, max => $ls_total);
|
||||||
|
|
||||||
|
$self->{output}->display();
|
||||||
|
$self->{output}->exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
||||||
|
|
||||||
|
__END__
|
||||||
|
|
||||||
|
=head1 MODE
|
||||||
|
|
||||||
|
Check service profiles status.
|
||||||
|
|
||||||
|
=over 8
|
||||||
|
|
||||||
|
=item B<--skip>
|
||||||
|
|
||||||
|
Skip 'offline' service profiles.
|
||||||
|
|
||||||
|
=item B<--warning>
|
||||||
|
|
||||||
|
Threshold warning for 'online' service profiles.
|
||||||
|
|
||||||
|
=item B<--critical>
|
||||||
|
|
||||||
|
Threshold critical for 'online' service profiles.
|
||||||
|
|
||||||
|
=back
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user