enhance qnap disk (#2454)

This commit is contained in:
qgarnier 2020-12-23 14:28:22 +01:00 committed by GitHub
parent b2ca082bea
commit 409f02406f
2 changed files with 85 additions and 42 deletions

View File

@ -30,89 +30,127 @@ my $map_status_disk = {
'-9' => 'rwError', '-9' => 'rwError',
'-4' => 'unknown' '-4' => 'unknown'
}; };
my $map_smartinfo = {
2 => 'abnormal',
1 => 'warning',
0 => 'good',
-1 => 'error'
};
# In MIB 'NAS.mib' # In MIB 'NAS.mib'
my $mapping = { my $mapping = {
HdDescr => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.2' }, description => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.2' }, # hdDescr
HdTemperature => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.3' }, temperature => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.3' }, # hdTemperature
HdStatus => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.4', map => $map_status_disk } status => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.4', map => $map_status_disk }, # HdStatus
smartinfo => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.7' } # HdSmartInfo
}; };
my $mapping2 = { my $mapping2 = {
HdSmartInfo => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.7' } description => { oid => '.1.3.6.1.4.1.24681.1.4.1.1.1.1.5.2.1.2' }, # diskID
status => { oid => '.1.3.6.1.4.1.24681.1.4.1.1.1.1.5.2.1.5', map => $map_smartinfo }, # diskSmartInfo
temperature => { oid => '.1.3.6.1.4.1.24681.1.4.1.1.1.1.5.2.1.6' } # diskTemperture
}; };
my $oid_HdEntry = '.1.3.6.1.4.1.24681.1.2.11.1'; my $oid_HdEntry = '.1.3.6.1.4.1.24681.1.2.11.1';
my $oid_diskTableEntry = '.1.3.6.1.4.1.24681.1.4.1.1.1.1.5.2.1';
sub load { sub load {
my ($self) = @_; my ($self) = @_;
push @{$self->{request}}, { oid => $oid_HdEntry, start => $mapping->{HdDescr}->{oid}, end => $mapping->{HdStatus}->{oid} }; push @{$self->{request}}, { oid => $oid_HdEntry, start => $mapping->{description}->{oid} };
push @{$self->{request}}, { oid => $mapping2->{HdSmartInfo}->{oid} }; push @{$self->{request}}, {
oid => $oid_diskTableEntry,
start => $mapping2->{description}->{oid},
end => $mapping2->{temperature}->{oid}
};
} }
sub check { sub check_disk {
my ($self) = @_; my ($self, %options) = @_;
$self->{output}->output_add(long_msg => "Checking disks"); return if (defined($self->{disk_checked}));
$self->{components}->{disk} = {name => 'disks', total => 0, skip => 0};
return if ($self->check_filter(section => 'disk'));
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_HdEntry}})) { foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $options{entry} }})) {
next if ($oid !~ /^$mapping->{HdDescr}->{oid}\.(\d+)$/); next if ($oid !~ /^$options{mapping}->{description}->{oid}\.(\d+)$/);
my $instance = $1; my $instance = $1;
$self->{disk_checked} = 1;
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_HdEntry}, instance => $instance);
my $result2 = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{ $mapping2->{HdSmartInfo}->{oid} }, instance => $instance); my $result = $self->{snmp}->map_instance(mapping => $options{mapping}, results => $self->{results}->{ $options{entry} }, instance => $instance);
next if ($self->check_filter(section => 'disk', instance => $instance)); next if ($self->check_filter(section => 'disk', instance => $instance));
next if ($result->{HdStatus} eq 'noDisk' && next if ($result->{status} eq 'noDisk' &&
$self->absent_problem(section => 'disk', instance => $instance)); $self->absent_problem(section => 'disk', instance => $instance));
$self->{components}->{disk}->{total}++; $self->{components}->{disk}->{total}++;
$self->{output}->output_add( $self->{output}->output_add(
long_msg => sprintf( long_msg => sprintf(
"Disk '%s' [instance: %s, temperature: %s, smart status: %s] status is %s.", "Disk '%s' [instance: %s, temperature: %s, smart status: %s] status is %s.",
$result->{HdDescr}, $instance, $result->{HdTemperature}, $result2->{HdSmartInfo}, $result->{HdStatus} $result->{description},
$instance,
$result->{temperature},
defined($result->{smartinfo}) ? $result->{smartinfo} : '-',
$result->{status}
) )
); );
my $exit = $self->get_severity(section => 'disk', value => $result->{HdStatus}); my $exit = $self->get_severity(section => 'disk', instance => $instance, value => $result->{status});
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( $self->{output}->output_add(
severity => $exit, severity => $exit,
short_msg => sprintf( short_msg => sprintf(
"Disk '%s' status is %s.", $result->{HdDescr}, $result->{HdStatus} "Disk '%s' status is %s.", $result->{description}, $result->{status}
)
);
}
$exit = $self->get_severity(section => 'smartdisk', value => $result2->{HdSmartInfo});
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(
severity => $exit,
short_msg => sprintf(
"Disk '%s' smart status is %s.", $result->{HdDescr}, $result2->{HdSmartInfo}
) )
); );
} }
if ($result->{HdTemperature} =~ /([0-9]+)\s*C/) { if (defined($result->{smartinfo})) {
my $disk_temp = $1; $exit = $self->get_severity(section => 'smartdisk', value => $result->{smartinfo});
my ($exit2, $warn, $crit) = $self->get_severity_numeric(section => 'disk', instance => $instance, value => $disk_temp); if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $exit2, severity => $exit,
short_msg => sprintf( short_msg => sprintf(
"Disk '%s' temperature is %s degree centigrade", $result->{HdDescr}, $disk_temp "Disk '%s' smart status is %s.", $result->{description}, $result->{smartinfo}
) )
); );
} }
$self->{output}->perfdata_add( }
label => 'temp_disk', unit => 'C',
nlabel => 'hardware.disk.temperature.celsius', next if ($result->{temperature} !~ /([0-9]+)/);
instances => $instance,
value => $disk_temp my $disk_temp = $1;
my ($exit2, $warn, $crit) = $self->get_severity_numeric(section => 'disk', instance => $instance, value => $disk_temp);
if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(
severity => $exit2,
short_msg => sprintf(
"Disk '%s' temperature is %s degree centigrade", $result->{description}, $disk_temp
)
); );
} }
$self->{output}->perfdata_add(
label => 'temp_disk',
nlabel => 'hardware.disk.temperature.celsius',
unit => 'C',
instances => $instance,
value => $disk_temp
);
} }
} }
sub check {
my ($self) = @_;
$self->{output}->output_add(long_msg => 'Checking disks');
$self->{components}->{disk} = { name => 'disks', total => 0, skip => 0 };
return if ($self->check_filter(section => 'disk'));
check_disk(
$self,
mapping => $mapping2,
entry => $oid_diskTableEntry
);
check_disk(
$self,
mapping => $mapping,
entry => $oid_HdEntry
);
}
1; 1;

View File

@ -39,7 +39,12 @@ sub set_system {
['ready', 'OK'], ['ready', 'OK'],
['invalid', 'CRITICAL'], ['invalid', 'CRITICAL'],
['rwError', 'CRITICAL'], ['rwError', 'CRITICAL'],
['unknown', 'UNKNOWN'] ['unknown', 'UNKNOWN'],
['abnormal', 'WARNING'],
['good', 'OK'],
['warning', 'WARNING'],
['error', 'CRITICAL']
], ],
smartdisk => [ smartdisk => [
['GOOD', 'OK'], ['GOOD', 'OK'],