fixed wrong oid and added more disk-states
This commit is contained in:
parent
12e5eaa741
commit
55362b7520
|
@ -28,23 +28,31 @@ my %map_states_disk = (
|
||||||
0 => 'online',
|
0 => 'online',
|
||||||
1 => 'missing',
|
1 => 'missing',
|
||||||
2 => 'not_compatible',
|
2 => 'not_compatible',
|
||||||
3 => 'failed',
|
3 => 'disc_failed',
|
||||||
4 => 'initializing',
|
4 => 'initializing',
|
||||||
5 => 'offline_requested',
|
5 => 'offline_requested',
|
||||||
6 => 'failed_requested',
|
6 => 'failed_requested',
|
||||||
|
7 => 'unconfigured_good_spun_up',
|
||||||
|
8 => 'unconfigured_good_spun_down',
|
||||||
|
9 => 'unconfigured_bad',
|
||||||
|
10 => 'hotspare',
|
||||||
|
11 => 'drive_offline',
|
||||||
|
12 => 'rebuild',
|
||||||
|
13 => 'failed',
|
||||||
|
14 => 'copyback',
|
||||||
255 => 'other_offline',
|
255 => 'other_offline',
|
||||||
);
|
);
|
||||||
|
|
||||||
my $mapping = {
|
my $mapping = {
|
||||||
raidDiskProductID => { oid => '.1.3.6.1.4.1.2620.1.6.7.7.2.1.6' },
|
raidDiskProductID => { oid => '.1.3.6.1.4.1.2620.1.6.7.7.2.1.6' },
|
||||||
raidDiskSyncState => { oid => '.1.3.6.1.4.1.2620.1.6.7.7.2.1.11', map => \%map_states_disk },
|
raidDiskState => { oid => '.1.3.6.1.4.1.2620.1.6.7.7.2.1.9', map => \%map_states_disk },
|
||||||
};
|
};
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $mapping->{raidDiskProductID}->{oid} },
|
push @{$self->{request}}, { oid => $mapping->{raidDiskProductID}->{oid} },
|
||||||
{ oid => $mapping->{raidDiskSyncState}->{oid} };
|
{ oid => $mapping->{raidDiskState}->{oid} };
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -57,19 +65,20 @@ sub check {
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$mapping->{raidDiskProductID}->{oid}}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$mapping->{raidDiskProductID}->{oid}}})) {
|
||||||
$oid =~ /^$mapping->{raidDiskProductID}->{oid}\.(.*)$/;
|
$oid =~ /^$mapping->{raidDiskProductID}->{oid}\.(.*)$/;
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$mapping->{raidDiskSyncState}->{oid}}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(mapping => $mapping, results =>
|
||||||
|
$self->{results}->{$mapping->{raidDiskState}->{oid}}, instance => $instance);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'raiddisk', instance => $instance));
|
next if ($self->check_filter(section => 'raiddisk', instance => $instance));
|
||||||
|
|
||||||
my $name = centreon::plugins::misc::trim($self->{results}->{$mapping->{raidDiskProductID}->{oid}}->{$oid});
|
my $name = centreon::plugins::misc::trim($self->{results}->{$mapping->{raidDiskProductID}->{oid}}->{$oid});
|
||||||
$self->{components}->{raiddisk}->{total}++;
|
$self->{components}->{raiddisk}->{total}++;
|
||||||
$self->{output}->output_add(long_msg => sprintf("raid disk '%s' status is '%s'",
|
$self->{output}->output_add(long_msg => sprintf("raid disk '%s' status is '%s'",
|
||||||
$name, $result->{raidDiskSyncState}));
|
$name, $result->{raidDiskState}));
|
||||||
my $exit = $self->get_severity(section => 'raiddisk', value => $result->{raidDiskSyncState});
|
my $exit = $self->get_severity(section => 'raiddisk', value => $result->{raidDiskState});
|
||||||
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("Raid disk '%s' status is '%s'",
|
short_msg => sprintf("Raid disk '%s' status is '%s'",
|
||||||
$name, $result->{raidDiskSyncState}));
|
$name, $result->{raidDiskState}));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue