This commit is contained in:
garnier-quentin 2020-12-01 15:27:57 +01:00
parent 73d3d8bd2b
commit fd853ed105
5 changed files with 73 additions and 32 deletions

View File

@ -23,22 +23,22 @@ package storage::qnap::snmp::mode::components::disk;
use strict; use strict;
use warnings; use warnings;
my %map_status_disk = ( my $map_status_disk = {
0 => 'ready', 0 => 'ready',
'-5' => 'noDisk', '-5' => 'noDisk',
'-6' => 'invalid', '-6' => 'invalid',
'-9' => 'rwError', '-9' => 'rwError',
'-4' => 'unknown', '-4' => 'unknown'
); };
# 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' }, HdDescr => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.2' },
HdTemperature => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.3' }, HdTemperature => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.3' },
HdStatus => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.4', map => \%map_status_disk }, HdStatus => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.4', map => $map_status_disk }
}; };
my $mapping2 = { my $mapping2 = {
HdSmartInfo => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.7' }, HdSmartInfo => { oid => '.1.3.6.1.4.1.24681.1.2.11.1.7' }
}; };
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';
@ -68,26 +68,42 @@ sub check {
$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(long_msg => sprintf("Disk '%s' [instance: %s, temperature: %s, smart status: %s] status is %s.", $self->{output}->output_add(
$result->{HdDescr}, $instance, $result->{HdTemperature}, $result2->{HdSmartInfo}, $result->{HdStatus})); long_msg => sprintf(
"Disk '%s' [instance: %s, temperature: %s, smart status: %s] status is %s.",
$result->{HdDescr}, $instance, $result->{HdTemperature}, $result2->{HdSmartInfo}, $result->{HdStatus}
)
);
my $exit = $self->get_severity(section => 'disk', value => $result->{HdStatus}); my $exit = $self->get_severity(section => 'disk', value => $result->{HdStatus});
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(
short_msg => sprintf("Disk '%s' status is %s.", $result->{HdDescr}, $result->{HdStatus})); severity => $exit,
short_msg => sprintf(
"Disk '%s' status is %s.", $result->{HdDescr}, $result->{HdStatus}
)
);
} }
$exit = $self->get_severity(section => 'smartdisk', value => $result2->{HdSmartInfo}); $exit = $self->get_severity(section => 'smartdisk', value => $result2->{HdSmartInfo});
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(
short_msg => sprintf("Disk '%s' smart status is %s.", $result->{HdDescr}, $result2->{HdSmartInfo})); severity => $exit,
short_msg => sprintf(
"Disk '%s' smart status is %s.", $result->{HdDescr}, $result2->{HdSmartInfo}
)
);
} }
if ($result->{HdTemperature} =~ /([0-9]+)\s*C/) { if ($result->{HdTemperature} =~ /([0-9]+)\s*C/) {
my $disk_temp = $1; my $disk_temp = $1;
my ($exit2, $warn, $crit) = $self->get_severity_numeric(section => 'disk', instance => $instance, value => $disk_temp); 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)) { if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $exit2, $self->{output}->output_add(
short_msg => sprintf("Disk '%s' temperature is %s degree centigrade", $result->{HdDescr}, $disk_temp)); severity => $exit2,
short_msg => sprintf(
"Disk '%s' temperature is %s degree centigrade", $result->{HdDescr}, $disk_temp
)
);
} }
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => 'temp_disk', unit => 'C', label => 'temp_disk', unit => 'C',

View File

@ -51,15 +51,23 @@ sub check {
next if ($self->check_filter(section => 'fan', instance => $instance)); next if ($self->check_filter(section => 'fan', instance => $instance));
$self->{components}->{fan}->{total}++; $self->{components}->{fan}->{total}++;
$self->{output}->output_add(long_msg => sprintf("fan '%s' [instance: %s] speed is '%s'.", $self->{output}->output_add(
$fan_descr, $instance, $fan_speed)); long_msg => sprintf(
"fan '%s' [instance: %s] speed is '%s'.",
$fan_descr, $instance, $fan_speed
)
);
if ($fan_speed =~ /([0-9]+)\s*rpm/i) { if ($fan_speed =~ /([0-9]+)\s*rpm/i) {
my $fan_speed_value = $1; my $fan_speed_value = $1;
my ($exit, $warn, $crit) = $self->get_severity_numeric(section => 'fan', instance => $instance, value => $fan_speed_value); my ($exit, $warn, $crit) = $self->get_severity_numeric(section => 'fan', instance => $instance, value => $fan_speed_value);
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(
short_msg => sprintf("Fan '%s' speed is %s rpm", $fan_descr, $fan_speed_value)); severity => $exit,
short_msg => sprintf(
"Fan '%s' speed is %s rpm", $fan_descr, $fan_speed_value
)
);
} }
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => 'fan', unit => 'rpm', label => 'fan', unit => 'rpm',

View File

@ -47,12 +47,20 @@ sub check {
my $status = $self->{results}->{$oid_raidStatus}->{$oid}; my $status = $self->{results}->{$oid_raidStatus}->{$oid};
$self->{components}->{raid}->{total}++; $self->{components}->{raid}->{total}++;
$self->{output}->output_add(long_msg => sprintf("raid '%s' status is %s [instance: %s]", $self->{output}->output_add(
$instance, $status, $instance)); long_msg => sprintf(
"raid '%s' status is %s [instance: %s]",
$instance, $status, $instance
)
);
my $exit = $self->get_severity(section => 'raid', value => $status); my $exit = $self->get_severity(section => 'raid', value => $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(severity => $exit, $self->{output}->output_add(
short_msg => sprintf("Raid '%s' status is %s.", $instance, $status)); severity => $exit,
short_msg => sprintf(
"Raid '%s' status is %s.", $instance, $status
)
);
} }
} }
} }

View File

@ -47,12 +47,20 @@ sub check {
if ($cpu_temp =~ /([0-9]+)\s*C/ && !$self->check_filter(section => 'temperature', instance => 'cpu')) { if ($cpu_temp =~ /([0-9]+)\s*C/ && !$self->check_filter(section => 'temperature', instance => 'cpu')) {
my $value = $1; my $value = $1;
$self->{components}->{temperature}->{total}++; $self->{components}->{temperature}->{total}++;
$self->{output}->output_add(long_msg => sprintf("cpu temperature is '%s' degree centigrade", $self->{output}->output_add(
$value)); long_msg => sprintf(
"cpu temperature is '%s' degree centigrade",
$value
)
);
my ($exit, $warn, $crit) = $self->get_severity_numeric(section => 'temperature', instance => 'cpu', value => $value); my ($exit, $warn, $crit) = $self->get_severity_numeric(section => 'temperature', instance => 'cpu', value => $value);
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(
short_msg => sprintf("CPU Temperature is '%s' degree centigrade", $value)); severity => $exit,
short_msg => sprintf(
"CPU Temperature is '%s' degree centigrade", $value
)
);
} }
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => 'temp', unit => 'C', label => 'temp', unit => 'C',

View File

@ -38,28 +38,29 @@ sub set_system {
['ready', 'OK'], ['ready', 'OK'],
['invalid', 'CRITICAL'], ['invalid', 'CRITICAL'],
['rwError', 'CRITICAL'], ['rwError', 'CRITICAL'],
['unknown', 'UNKNOWN'], ['unknown', 'UNKNOWN']
], ],
smartdisk => [ smartdisk => [
['GOOD', 'OK'], ['GOOD', 'OK'],
['NORMAL', 'OK'], ['NORMAL', 'OK'],
['--', 'OK'], ['--', 'OK'],
['.*', 'CRITICAL'], ['.*', 'CRITICAL']
], ],
raid => [ raid => [
['Ready', 'OK'], ['Ready', 'OK'],
['Synchronizing', 'OK'],
['degraded', 'WARNING'], ['degraded', 'WARNING'],
['.*', 'CRITICAL'], ['.*', 'CRITICAL']
], ]
}; };
$self->{components_path} = 'storage::qnap::snmp::mode::components'; $self->{components_path} = 'storage::qnap::snmp::mode::components';
$self->{components_module} = ['temperature', 'disk', 'fan', 'raid']; $self->{components_module} = ['temperature', 'disk', 'fan', 'raid'];
} }
sub snmp_execute { sub snmp_execute {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{snmp} = $options{snmp}; $self->{snmp} = $options{snmp};
$self->{results} = $self->{snmp}->get_multiple_table(oids => $self->{request}); $self->{results} = $self->{snmp}->get_multiple_table(oids => $self->{request});
} }