centreon-plugins/network/alcatel/omniswitch/snmp/mode/cpu.pm

185 lines
7.3 KiB
Perl
Raw Normal View History

2014-07-23 18:10:11 +02:00
#
2021-02-08 09:55:50 +01:00
# Copyright 2021 Centreon (http://www.centreon.com/)
2015-07-21 11:51:02 +02:00
#
# Centreon is a full-fledged industry-strength solution that meets
# the needs in IT infrastructure and application monitoring for
# service performance.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
2014-07-23 18:10:11 +02:00
2017-05-17 16:43:37 +02:00
package network::alcatel::omniswitch::snmp::mode::cpu;
2014-07-23 18:10:11 +02:00
use base qw(centreon::plugins::mode);
use strict;
use warnings;
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
bless $self, $class;
2019-03-20 16:04:52 +01:00
$options{options}->add_options(arguments => {
"warning:s" => { name => 'warning', default => '' },
"critical:s" => { name => 'critical', default => '' },
});
2014-07-23 18:10:11 +02:00
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::init(%options);
($self->{warn1m}, $self->{warn1h}) = split /,/, $self->{option_results}->{warning};
($self->{crit1m}, $self->{crit1h}) = split /,/, $self->{option_results}->{critical};
if (($self->{perfdata}->threshold_validate(label => 'warn1m', value => $self->{warn1m})) == 0) {
$self->{output}->add_option_msg(short_msg => "Wrong warning (1min) threshold '" . $self->{warn1m} . "'.");
$self->{output}->option_exit();
}
if (($self->{perfdata}->threshold_validate(label => 'warn1h', value => $self->{warn1h})) == 0) {
$self->{output}->add_option_msg(short_msg => "Wrong warning (1hour) threshold '" . $self->{warn1h} . "'.");
$self->{output}->option_exit();
}
if (($self->{perfdata}->threshold_validate(label => 'crit1m', value => $self->{crit1m})) == 0) {
$self->{output}->add_option_msg(short_msg => "Wrong critical (1min) threshold '" . $self->{crit1m} . "'.");
$self->{output}->option_exit();
}
if (($self->{perfdata}->threshold_validate(label => 'crit5h', value => $self->{crit5})) == 0) {
2014-07-24 11:47:28 +02:00
$self->{output}->add_option_msg(short_msg => "Wrong critical (1hour) threshold '" . $self->{crit1h} . "'.");
2014-07-23 18:10:11 +02:00
$self->{output}->option_exit();
}
}
2014-07-24 11:47:28 +02:00
sub check_cpu {
2014-07-23 18:10:11 +02:00
my ($self, %options) = @_;
2019-03-20 16:04:52 +01:00
my $exit1 = $self->{perfdata}->threshold_check(
value => $options{'1min'},
threshold => [
{ label => 'crit1m', exit_litteral => 'critical' },
{ label => 'warn1m', exit_litteral => 'warning' },
]
);
my $exit2 = $self->{perfdata}->threshold_check(
value => $options{'1hour'},
threshold => [
{ label => 'crit1h', exit_litteral => 'critical' },
{ label => 'warn1h', exit_litteral => 'warning' },
]
);
2014-07-23 18:10:11 +02:00
my $exit = $self->{output}->get_most_critical(status => [ $exit1, $exit2 ]);
$self->{output}->output_add(severity => $exit,
2014-07-24 11:47:28 +02:00
short_msg => sprintf("%s: %.2f%% (1min), %.2f%% (1hour)", $options{name}, $options{'1min'}, $options{'1hour'}));
2014-07-23 18:10:11 +02:00
2014-07-24 11:47:28 +02:00
$self->{output}->perfdata_add(label => "cpu1m" . $options{perf_label} , unit => '%',
value => $options{'1min'},
2014-07-23 18:10:11 +02:00
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn1m'),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit1m'),
min => 0, max => 100);
2014-07-24 11:47:28 +02:00
$self->{output}->perfdata_add(label => "cpu1h" . $options{perf_label} , unit => '%',
value => $options{'1hour'},
2014-07-23 18:10:11 +02:00
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn1h'),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit1h'),
min => 0, max => 100);
2014-07-24 11:47:28 +02:00
}
2014-07-23 18:10:11 +02:00
2014-07-24 11:47:28 +02:00
sub run {
my ($self, %options) = @_;
2014-07-23 18:10:11 +02:00
2019-03-20 16:04:52 +01:00
my $mapping = {
aos6 => {
entry_device => '.1.3.6.1.4.1.6486.800.1.2.1.16.1.1.1',
entry_module => '.1.3.6.1.4.1.6486.800.1.2.1.16.1.1.2.1.1',
device => {
healthDeviceCpu1MinAvg => { oid => '.1.3.6.1.4.1.6486.800.1.2.1.16.1.1.1.14' },
healthDeviceCpu1HrAvg => { oid => '.1.3.6.1.4.1.6486.800.1.2.1.16.1.1.1.15' },
},
module => {
healthModuleCpu1MinAvg => { oid => '.1.3.6.1.4.1.6486.800.1.2.1.16.1.1.2.1.1.15' },
healthModuleCpu1HrAvg => { oid => '.1.3.6.1.4.1.6486.800.1.2.1.16.1.1.2.1.1.16' },
},
},
aos7 => {
entry_module => '.1.3.6.1.4.1.6486.801.1.2.1.16.1.1.1.1.1',
module => {
healthModuleCpu1MinAvg => { oid => '.1.3.6.1.4.1.6486.801.1.2.1.16.1.1.1.1.1.11' },
healthModuleCpu1HrAvg => { oid => '.1.3.6.1.4.1.6486.801.1.2.1.16.1.1.1.1.1.12' },
},
},
};
2019-03-21 08:26:46 +01:00
2019-03-20 16:04:52 +01:00
my $snmp_result = $options{snmp}->get_multiple_table(oids => [
{ oid => $mapping->{aos6}->{entry_device}, start => $mapping->{aos6}->{device}->{healthDeviceCpu1MinAvg}->{oid}, end => $mapping->{aos6}->{device}->{healthDeviceCpu1HrAvg}->{oid} },
{ oid => $mapping->{aos6}->{entry_module}, start => $mapping->{aos6}->{module}->{healthModuleCpu1MinAvg}->{oid}, end => $mapping->{aos6}->{module}->{healthModuleCpu1HrAvg}->{oid} },
{ oid => $mapping->{aos7}->{entry_module}, start => $mapping->{aos7}->{module}->{healthModuleCpu1MinAvg}->{oid}, end => $mapping->{aos7}->{module}->{healthModuleCpu1HrAvg}->{oid} },
], nothing_quit => 1);
2014-07-24 11:47:28 +02:00
2019-03-20 16:04:52 +01:00
my $type = 'aos6';
if (scalar(keys %{$snmp_result->{ $mapping->{aos7}->{entry_module} }}) > 0) {
$type = 'aos7';
}
if (defined($mapping->{$type}->{device})) {
my $result = $options{snmp}->map_instance(mapping => $mapping->{$type}->{device}, results => $snmp_result->{ $mapping->{$type}->{entry_device} }, instance => '0');
$self->check_cpu(
name => 'Device cpu',
perf_label => '_device',
'1min' => $result->{healthDeviceCpu1MinAvg},
'1hour' => $result->{healthDeviceCpu1HrAvg}
);
}
2014-07-24 11:47:28 +02:00
2019-03-20 16:04:52 +01:00
foreach my $oid ($options{snmp}->oid_lex_sort(keys %{$snmp_result->{ $mapping->{$type}->{entry_module} }})) {
2019-03-21 08:26:46 +01:00
next if ($oid !~ /^$mapping->{$type}->{module}->{healthModuleCpu1MinAvg}->{oid}\.(.*)$/);
2019-03-20 16:04:52 +01:00
my $result = $options{snmp}->map_instance(mapping => $mapping->{$type}->{module}, results => $snmp_result->{ $mapping->{$type}->{entry_module} }, instance => $1);
$self->check_cpu(
name => "Module cpu '$1'",
perf_label => "_module_$1",
'1min' => $result->{healthModuleCpu1MinAvg},
'1hour' => $result->{healthModuleCpu1HrAvg}
);
2014-07-24 11:47:28 +02:00
}
2014-07-23 18:10:11 +02:00
$self->{output}->display();
$self->{output}->exit();
}
1;
__END__
=head1 MODE
2014-07-24 11:47:28 +02:00
Check cpu usage (AlcatelIND1Health.mib).
2014-07-23 18:10:11 +02:00
=over 8
=item B<--warning>
Threshold warning in percent (1m,1h).
=item B<--critical>
Threshold critical in percent (1m,1h).
=back
=cut