mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-28 16:14:21 +02:00
Fix #2395
This commit is contained in:
parent
73d3d8bd2b
commit
fd853ed105
@ -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',
|
||||||
|
@ -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',
|
||||||
|
@ -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
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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',
|
||||||
|
@ -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});
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user