centreon-plugins/apps/monitoring/netdata/restapi/mode/traffic.pm

182 lines
5.9 KiB
Perl
Raw Normal View History

2020-06-26 18:34:54 +02:00
#
# Copyright 2020 Centreon (http://www.centreon.com/)
#
# 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.
#
package apps::monitoring::netdata::restapi::mode::traffic;
use base qw(centreon::plugins::templates::counter);
use strict;
use warnings;
sub prefix_traffic_output {
my ($self, %options) = @_;
return "Interface '" . $options{instance_value}->{display} . "' ";
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'interfaces', type => 1, cb_prefix_output => 'prefix_traffic_output', message_multiple => 'All interfaces are ok' }
];
$self->{maps_counters}->{interfaces} = [
2020-06-29 13:55:01 +02:00
{ label => 'traffic-in', nlabel => 'network.traffic.in.bitspersecond', set => {
key_values => [ { name => 'traffic_in' }, { name => 'speed' }, { name => 'display' } ],
output_template => 'traffic in: %.2f%s/s',
2020-06-26 18:34:54 +02:00
output_change_bytes => 2,
perfdatas => [
2020-06-29 13:55:01 +02:00
{ template => '%d', min => 0, max => 'speed', unit => 'b/s', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
2020-06-26 18:34:54 +02:00
]
}
},
2020-06-29 13:55:01 +02:00
{ label => 'traffic-out', nlabel => 'network.traffic.out.bitspersecond', set => {
key_values => [ { name => 'traffic_out' }, { name => 'speed' }, { name => 'display' } ],
output_template => 'traffic out: %.2f%s/s',
2020-06-26 18:34:54 +02:00
output_change_bytes => 2,
perfdatas => [
2020-06-29 13:55:01 +02:00
{ template => '%d', min => 0, max => 'speed', unit => 'b/s', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
2020-06-26 18:34:54 +02:00
]
}
2020-06-29 13:55:01 +02:00
}
2020-06-26 18:34:54 +02:00
];
}
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
bless $self, $class;
$options{options}->add_options(arguments => {
2020-06-29 13:55:01 +02:00
'chart-period:s' => { name => 'chart_period', default => '300' },
'chart-statistics:s' => { name => 'chart_statistics', default => 'average' },
'interface-name:s' => { name => 'interface_name' },
'speed:s' => { name => 'speed' }
2020-06-26 18:34:54 +02:00
});
return $self;
}
sub manage_selection {
my ($self, %options) = @_;
my $full_list = $options{custom}->list_charts();
2020-06-29 13:55:01 +02:00
my $interface_list = [];
2020-06-26 18:34:54 +02:00
foreach my $chart (values %{$full_list->{charts}}) {
next if ($chart->{name} !~ '^net\.');
2020-06-29 13:55:01 +02:00
push @$interface_list, { name => $chart->{name}, speed => $chart->{chart_variables}->{nic_speed_max} };
2020-06-26 18:34:54 +02:00
}
2020-06-29 13:55:01 +02:00
$self->{interfaces} = {};
foreach my $int (@$interface_list) {
2020-06-26 18:34:54 +02:00
my $result = $options{custom}->get_data(
2020-06-29 13:55:01 +02:00
chart => $int->{name},
2020-06-26 18:34:54 +02:00
dimensions => 'received,sent',
points => $self->{option_results}->{chart_point},
after_period => $self->{option_results}->{chart_period},
group => $self->{option_results}->{chart_statistics},
absolute => 1
);
2020-06-29 13:55:01 +02:00
$int->{name} =~ s/net.//;
2020-06-26 18:34:54 +02:00
next if (defined($self->{option_results}->{interface_name}) &&
$self->{option_results}->{interface_name} ne '' &&
2020-06-29 13:55:01 +02:00
$int->{name} !~ /$self->{option_results}->{interface_name}/
2020-06-26 18:34:54 +02:00
);
2020-06-29 13:55:01 +02:00
my $count = 0;
# In Kb/s
my $metrics = { received => 0, sent => 0 };
foreach my $data (@{$result->{data}}) {
while (my ($index, $label) = each(@{$result->{labels}})) {
$metrics->{$label} += $data->[$index];
2020-06-26 18:34:54 +02:00
}
2020-06-29 13:55:01 +02:00
$count++;
2020-06-26 18:34:54 +02:00
}
2020-06-29 13:55:01 +02:00
$self->{interfaces}->{ $int->{name} } = {
display => $int->{name},
traffic_in => $metrics->{received} * 1000,
traffic_out => $metrics->{sent} * 1000,
speed => defined($self->{option_results}->{speed}) && $self->{option_results}->{speed} ne '' ?
$self->{option_results}->{speed} : $int->{speed} * 1000 * 1000
2020-06-26 18:34:54 +02:00
};
}
if (scalar(keys %{$self->{interfaces}}) <= 0) {
$self->{output}->add_option_msg(short_msg => 'No interfaces found');
$self->{output}->option_exit();
}
};
1;
__END__
=head1 MODE
Check traffic on interfaces of *nix based servers using the Netdata agent RestAPI.
Example:
perl centreon_plugins.pl --plugin=apps::monitoring::netdata::restapi::plugin
--mode=traffic --hostname=10.0.0.1 --chart-period=300 --warning-traffic-in='70000000' --critical-traffic-in='80000000' --verbose
More information on 'https://learn.netdata.cloud/docs/agent/web/api'.
=over 8
=item B<--chart-period>
The period in seconds on which the values are calculated
Default: 300
=item B<--chart-statistic>
The statistic calculation method used to parse the collected data.
Can be : average, sum, min, max
Default: average
=item B<--interface-name>
Filter on a specific interface. Regexp can be used.
Example: --interface-name='^eth0$'
=item B<--speed>
2020-06-29 13:55:01 +02:00
Set interfaces speed in b/s.
Default: 1000000000 (1Gb/s).
2020-06-26 18:34:54 +02:00
=item B<--warning-traffic-*>
Warning threshold on interface traffic where '*' can be:
in,out.
=item B<--critical-traffic-*>
Critical threshold on interface traffic where '*' can be:
in,out.
=back
=cut