mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-25 22:55:15 +02:00
+ Enhance cisco ucs equipment mode (WIP)
This commit is contained in:
parent
ecb978a97b
commit
749b080286
@ -22,14 +22,14 @@ package hardware::server::cisco::ucs::mode::components::localdisk;
|
|||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::server::cisco::ucs::mode::components::resources qw(%mapping_presence %mapping_drive_status);
|
use hardware::server::cisco::ucs::mode::components::resources qw(%mapping_presence %mapping_operability);
|
||||||
|
|
||||||
# In MIB 'CISCO-UNIFIED-COMPUTING-STORAGE-MIB'
|
# In MIB 'CISCO-UNIFIED-COMPUTING-STORAGE-MIB'
|
||||||
my $mapping1 = {
|
my $mapping1 = {
|
||||||
cucsStorageLocalDiskPresence => { oid => '.1.3.6.1.4.1.9.9.719.1.45.4.1.10', map => \%mapping_presence },
|
cucsStorageLocalDiskPresence => { oid => '.1.3.6.1.4.1.9.9.719.1.45.4.1.10', map => \%mapping_presence },
|
||||||
};
|
};
|
||||||
my $mapping2 = {
|
my $mapping2 = {
|
||||||
cucsStorageLocalDiskDiskState => { oid => '.1.3.6.1.4.1.9.9.719.1.45.4.1.18', map => \%mapping_drive_status },
|
cucsStorageLocalDiskOperability => { oid => '.1.3.6.1.4.1.9.9.719.1.45.4.1.18', map => \%mapping_operability },
|
||||||
};
|
};
|
||||||
my $oid_cucsStorageLocalDiskDn = '.1.3.6.1.4.1.9.9.719.1.30.11.1.2';
|
my $oid_cucsStorageLocalDiskDn = '.1.3.6.1.4.1.9.9.719.1.30.11.1.2';
|
||||||
|
|
||||||
@ -37,7 +37,7 @@ sub load {
|
|||||||
my (%options) = @_;
|
my (%options) = @_;
|
||||||
|
|
||||||
push @{$options{request}}, { oid => $mapping1->{cucsStorageLocalDiskPresence}->{oid} },
|
push @{$options{request}}, { oid => $mapping1->{cucsStorageLocalDiskPresence}->{oid} },
|
||||||
{ oid => $mapping2->{cucsStorageLocalDiskDiskState}->{oid} }, { oid => $oid_cucsStorageLocalDiskDn };
|
{ oid => $mapping2->{cucsStorageLocalDiskOperability}->{oid} }, { oid => $oid_cucsStorageLocalDiskDn };
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
@ -52,13 +52,13 @@ sub check {
|
|||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $localdisk_dn = $self->{results}->{$oid_cucsStorageLocalDiskDn}->{$oid};
|
my $localdisk_dn = $self->{results}->{$oid_cucsStorageLocalDiskDn}->{$oid};
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping1, results => $self->{results}->{$mapping1->{cucsStorageLocalDiskPresence}->{oid}}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(mapping => $mapping1, results => $self->{results}->{$mapping1->{cucsStorageLocalDiskPresence}->{oid}}, instance => $instance);
|
||||||
my $result2 = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{$mapping2->{cucsStorageLocalDiskDiskState}->{oid}}, instance => $instance);
|
my $result2 = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{$mapping2->{cucsStorageLocalDiskOperability}->{oid}}, instance => $instance);
|
||||||
|
|
||||||
next if ($self->absent_problem(section => 'localdisk', instance => $localdisk_dn));
|
next if ($self->absent_problem(section => 'localdisk', instance => $localdisk_dn));
|
||||||
next if ($self->check_exclude(section => 'localdisk', instance => $localdisk_dn));
|
next if ($self->check_exclude(section => 'localdisk', instance => $localdisk_dn));
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("local disk '%s' state is '%s' [presence: %s].",
|
$self->{output}->output_add(long_msg => sprintf("local disk '%s' state is '%s' [presence: %s].",
|
||||||
$localdisk_dn, $result2->{cucsStorageLocalDiskDiskState},
|
$localdisk_dn, $result2->{cucsStorageLocalDiskOperability},
|
||||||
$result->{cucsStorageLocalDiskPresence})
|
$result->{cucsStorageLocalDiskPresence})
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -73,11 +73,11 @@ sub check {
|
|||||||
|
|
||||||
$self->{components}->{localdisk}->{total}++;
|
$self->{components}->{localdisk}->{total}++;
|
||||||
|
|
||||||
$exit = $self->get_severity(section => 'localdisk.drivestatus', label => 'default.drivestatus', value => $result2->{cucsStorageLocalDiskDiskState});
|
$exit = $self->get_severity(section => 'localdisk.operability', label => 'default.operability', value => $result2->{cucsStorageLocalDiskOperability});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(severity => $exit,
|
||||||
short_msg => sprintf("local disk '%s' state is '%s'",
|
short_msg => sprintf("local disk '%s' state is '%s'",
|
||||||
$localdisk_dn, $result2->{cucsStorageLocalDiskDiskState}
|
$localdisk_dn, $result2->{cucsStorageLocalDiskOperability}
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -51,6 +51,7 @@ sub check {
|
|||||||
$oid =~ /\.(\d+)$/;
|
$oid =~ /\.(\d+)$/;
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $memory_dn = $self->{results}->{$oid_cucsMemoryUnitDn}->{$oid};
|
my $memory_dn = $self->{results}->{$oid_cucsMemoryUnitDn}->{$oid};
|
||||||
|
$memory_dn =~ s/\n$//ms;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping1, results => $self->{results}->{$mapping1->{cucsMemoryUnitPresence}->{oid}}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(mapping => $mapping1, results => $self->{results}->{$mapping1->{cucsMemoryUnitPresence}->{oid}}, instance => $instance);
|
||||||
my $result2 = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{$mapping2->{cucsMemoryUnitOperState}->{oid}}, instance => $instance);
|
my $result2 = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{$mapping2->{cucsMemoryUnitOperState}->{oid}}, instance => $instance);
|
||||||
|
|
||||||
|
@ -90,6 +90,7 @@ our @EXPORT_OK = qw($thresholds %mapping_presence %mapping_operability %mapping_
|
|||||||
105 => 'upgradeProblem',
|
105 => 'upgradeProblem',
|
||||||
106 => 'peerCommProblem',
|
106 => 'peerCommProblem',
|
||||||
107 => 'autoUpgrade',
|
107 => 'autoUpgrade',
|
||||||
|
108 => 'linkActivateBlocked',
|
||||||
);
|
);
|
||||||
%mapping_overall_status = (
|
%mapping_overall_status = (
|
||||||
0 => 'indeterminate',
|
0 => 'indeterminate',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user