parent
d355a224eb
commit
7bdc08af54
|
@ -44,6 +44,25 @@ my %map_sensor_type = (
|
||||||
13 => 'specialEnum',
|
13 => 'specialEnum',
|
||||||
14 => 'dBm',
|
14 => 'dBm',
|
||||||
);
|
);
|
||||||
|
my %map_scale = (
|
||||||
|
1 => -24, # yocto,
|
||||||
|
2 => -21, # zepto
|
||||||
|
3 => -18, # atto
|
||||||
|
4 => -15, # femto
|
||||||
|
5 => -12, # pico
|
||||||
|
6 => -9, # nano
|
||||||
|
7 => -6, # micro
|
||||||
|
8 => -3, # milli
|
||||||
|
9 => 0, #units
|
||||||
|
10 => 3, #kilo
|
||||||
|
11 => 6, #mega
|
||||||
|
12 => 9, #giga
|
||||||
|
13 => 12, #tera
|
||||||
|
14 => 18, #exa
|
||||||
|
15 => 15, #peta
|
||||||
|
16 => 21, #zetta
|
||||||
|
17 => 24, #yotta
|
||||||
|
);
|
||||||
my %map_severity = (
|
my %map_severity = (
|
||||||
1 => 'other',
|
1 => 'other',
|
||||||
10 => 'minor',
|
10 => 'minor',
|
||||||
|
@ -58,10 +77,27 @@ my %map_relation = (
|
||||||
5 => 'equalTo',
|
5 => 'equalTo',
|
||||||
6 => 'notEqualTo',
|
6 => 'notEqualTo',
|
||||||
);
|
);
|
||||||
|
my %perfdata_unit = (
|
||||||
|
'other' => '',
|
||||||
|
'unknown' => '',
|
||||||
|
'voltsAC' => 'V',
|
||||||
|
'voltsDC' => 'V',
|
||||||
|
'amperes' => 'A',
|
||||||
|
'watts' => 'W',
|
||||||
|
'hertz' => 'Hz',
|
||||||
|
'celsius' => 'C',
|
||||||
|
'percentRH' => '%',
|
||||||
|
'rpm' => 'rpm',
|
||||||
|
'cmm' => '',
|
||||||
|
'truthvalue' => '',
|
||||||
|
'specialEnum' => '',
|
||||||
|
'dBm' => 'dBm',
|
||||||
|
);
|
||||||
|
|
||||||
# In MIB 'CISCO-ENTITY-SENSOR-MIB'
|
# In MIB 'CISCO-ENTITY-SENSOR-MIB'
|
||||||
my $mapping = {
|
my $mapping = {
|
||||||
entSensorType => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.1', map => \%map_sensor_type },
|
entSensorType => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.1', map => \%map_sensor_type },
|
||||||
|
entSensorScale => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.2', map => \%map_scale },
|
||||||
entSensorPrecision => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.3' },
|
entSensorPrecision => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.3' },
|
||||||
entSensorValue => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.4' },
|
entSensorValue => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.4' },
|
||||||
entSensorStatus => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.5', map => \%map_sensor_status },
|
entSensorStatus => { oid => '.1.3.6.1.4.1.9.9.91.1.1.1.1.5', map => \%map_sensor_status },
|
||||||
|
@ -73,6 +109,7 @@ my $mapping2 = {
|
||||||
};
|
};
|
||||||
my $oid_entSensorValueEntry = '.1.3.6.1.4.1.9.9.91.1.1.1.1';
|
my $oid_entSensorValueEntry = '.1.3.6.1.4.1.9.9.91.1.1.1.1';
|
||||||
my $oid_entSensorThresholdEntry = '.1.3.6.1.4.1.9.9.91.1.2.1.1';
|
my $oid_entSensorThresholdEntry = '.1.3.6.1.4.1.9.9.91.1.2.1.1';
|
||||||
|
my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2';
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my (%options) = @_;
|
my (%options) = @_;
|
||||||
|
@ -82,19 +119,60 @@ sub load {
|
||||||
|
|
||||||
sub get_default_warning_threshold {
|
sub get_default_warning_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $th = '';
|
my ($high_th, $low_th);
|
||||||
|
|
||||||
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_entSensorThresholdEntry}})) {
|
||||||
|
next if ($oid !~ /^$mapping2->{entSensorThresholdSeverity}->{oid}\.$options{instance}\.(.*)$/);
|
||||||
|
my $instance = $1;
|
||||||
|
my $result = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{$oid_entSensorThresholdEntry}, instance => $options{instance} . '.' . $instance);
|
||||||
|
next if ($result->{entSensorThresholdSeverity} ne 'minor');
|
||||||
|
|
||||||
|
my $value = $result->{entSensorThresholdValue} * (10 ** ($options{result}->{entSensorScale}) * (10 ** -($options{result}->{entSensorPrecision})));
|
||||||
|
if ($result->{entSensorThresholdRelation} eq 'greaterOrEqual') {
|
||||||
|
$high_th = $value - 0.01;
|
||||||
|
} elsif ($result->{entSensorThresholdRelation} eq 'greaterThan') {
|
||||||
|
$high_th = $value;
|
||||||
|
} elsif ($result->{entSensorThresholdRelation} eq 'lessOrEqual') {
|
||||||
|
$low_th = $value + 0.01;
|
||||||
|
} elsif ($result->{entSensorThresholdRelation} eq 'lessThan') {
|
||||||
|
$low_th = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
my $th = '';
|
||||||
|
$th = $low_th . ':' if (defined($low_th));
|
||||||
|
$th .= $high_th if (defined($high_th));
|
||||||
return $th;
|
return $th;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub get_default_critical_threshold {
|
sub get_default_critical_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $th = '';
|
my ($high_th, $low_th);
|
||||||
|
|
||||||
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_entSensorThresholdEntry}})) {
|
||||||
|
next if ($oid !~ /^$mapping2->{entSensorThresholdSeverity}->{oid}\.$options{instance}\.(.*)$/);
|
||||||
|
my $instance = $1;
|
||||||
|
my $result = $self->{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{$oid_entSensorThresholdEntry}, instance => $options{instance} . '.' . $instance);
|
||||||
|
next if ($result->{entSensorThresholdSeverity} !~ /major|critical/);
|
||||||
|
|
||||||
|
my $value = $result->{entSensorThresholdValue} * (10 ** ($options{result}->{entSensorScale}) * (10 ** -($options{result}->{entSensorPrecision})));
|
||||||
|
if ($result->{entSensorThresholdRelation} eq 'greaterOrEqual') {
|
||||||
|
$high_th = $value - 0.01;
|
||||||
|
} elsif ($result->{entSensorThresholdRelation} eq 'greaterThan') {
|
||||||
|
$high_th = $value;
|
||||||
|
} elsif ($result->{entSensorThresholdRelation} eq 'lessOrEqual') {
|
||||||
|
$low_th = $value + 0.01;
|
||||||
|
} elsif ($result->{entSensorThresholdRelation} eq 'lessThan') {
|
||||||
|
$low_th = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
my $th = '';
|
||||||
|
$th = $low_th . ':' if (defined($low_th));
|
||||||
|
$th .= $high_th if (defined($high_th));
|
||||||
return $th;
|
return $th;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
|
@ -112,13 +190,13 @@ sub check {
|
||||||
$self->{components}->{sensor}->{total}++;
|
$self->{components}->{sensor}->{total}++;
|
||||||
|
|
||||||
$result->{entSensorValue} = defined($result->{entSensorValue}) ?
|
$result->{entSensorValue} = defined($result->{entSensorValue}) ?
|
||||||
$result->{entSensorValue} * 10 ** -($result->{entSensorPrecision}) : undef;
|
$result->{entSensorValue} * (10 ** ($result->{entSensorScale}) * (10 ** -($result->{entSensorPrecision}))) : undef;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Sensor '%s' status is '%s' [instance: %s] [value: %s %s]",
|
$self->{output}->output_add(long_msg => sprintf("Sensor '%s' status is '%s' [instance: %s] [value: %s %s]",
|
||||||
$sensor_descr, $result->{entSensorStatus},
|
$sensor_descr, $result->{entSensorStatus},
|
||||||
$instance,
|
$instance,
|
||||||
defined($result->{entSensorValue}) ? $result->{entSensorValue} : '-'),
|
defined($result->{entSensorValue}) ? $result->{entSensorValue} : '-',
|
||||||
$result->{entSensorType});
|
$result->{entSensorType}));
|
||||||
my $exit = $self->get_severity(section => $result->{entSensorType}, label => 'sensor', value => $result->{entSensorStatus});
|
my $exit = $self->get_severity(section => $result->{entSensorType}, label => 'sensor', value => $result->{entSensorStatus});
|
||||||
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,
|
||||||
|
@ -131,8 +209,8 @@ sub check {
|
||||||
my $component = 'sensor.' . $result->{entSensorType};
|
my $component = 'sensor.' . $result->{entSensorType};
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => $component, instance => $instance, value => $result->{entSensorValue});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => $component, instance => $instance, value => $result->{entSensorValue});
|
||||||
if ($checked == 0) {
|
if ($checked == 0) {
|
||||||
my $warn_th = get_default_warning_threshold($self);
|
my $warn_th = get_default_warning_threshold($self, instance => $instance, result => $result);
|
||||||
my $crit_th = get_default_critical_threshold($self);
|
my $crit_th = get_default_critical_threshold($self, instance => $instance, result => $result);
|
||||||
$self->{perfdata}->threshold_validate(label => 'warning-' . $component . '-instance-' . $instance, value => $warn_th);
|
$self->{perfdata}->threshold_validate(label => 'warning-' . $component . '-instance-' . $instance, value => $warn_th);
|
||||||
$self->{perfdata}->threshold_validate(label => 'critical-' . $component . '-instance-' . $instance, value => $crit_th);
|
$self->{perfdata}->threshold_validate(label => 'critical-' . $component . '-instance-' . $instance, value => $crit_th);
|
||||||
$warn = $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $component . '-instance-' . $instance);
|
$warn = $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $component . '-instance-' . $instance);
|
||||||
|
@ -142,7 +220,7 @@ sub check {
|
||||||
$self->{output}->output_add(severity => $exit2,
|
$self->{output}->output_add(severity => $exit2,
|
||||||
short_msg => sprintf("Sensor '%s' is %s %s", $sensor_descr, $result->{entSensorStatus}, $result->{entSensorType}));
|
short_msg => sprintf("Sensor '%s' is %s %s", $sensor_descr, $result->{entSensorStatus}, $result->{entSensorType}));
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(label => $component . '_' . $sensor_descr,
|
$self->{output}->perfdata_add(label => $component . '_' . $sensor_descr, unit => $perfdata_unit{$result->{entSensorType}},
|
||||||
value => $result->{entSensorValue},
|
value => $result->{entSensorValue},
|
||||||
warning => $warn,
|
warning => $warn,
|
||||||
critical => $crit);
|
critical => $crit);
|
||||||
|
|
Loading…
Reference in New Issue