some change for netdata

This commit is contained in:
garnier-quentin 2020-06-29 13:55:01 +02:00
parent 4d043d04b8
commit db0fcd604d
11 changed files with 213 additions and 249 deletions

View File

@ -22,12 +22,8 @@ package apps::monitoring::netdata::restapi::custom::api;
use strict; use strict;
use warnings; use warnings;
use DateTime;
use centreon::plugins::http; use centreon::plugins::http;
use centreon::plugins::statefile;
use JSON::XS; use JSON::XS;
use URI::Encode;
use Digest::MD5 qw(md5_hex);
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
@ -49,8 +45,7 @@ sub new {
'port:s' => { name => 'port' }, 'port:s' => { name => 'port' },
'proto:s' => { name => 'proto' }, 'proto:s' => { name => 'proto' },
'timeout:s' => { name => 'timeout' }, 'timeout:s' => { name => 'timeout' },
'reload-cache-time:s' => { name => 'reload_cache_time' }, 'endpoint:s' => { name => 'endpoint'}
'endpoint:s' => { name => 'endpoint'},
}); });
} }
$options{options}->add_help(package => __PACKAGE__, sections => 'REST API OPTIONS', once => 1); $options{options}->add_help(package => __PACKAGE__, sections => 'REST API OPTIONS', once => 1);
@ -93,6 +88,11 @@ sub check_options {
$self->{timeout} = (defined($self->{option_results}->{timeout})) ? $self->{option_results}->{timeout} : 10; $self->{timeout} = (defined($self->{option_results}->{timeout})) ? $self->{option_results}->{timeout} : 10;
$self->{endpoint} = (defined($self->{option_results}->{endpoint})) ? $self->{option_results}->{endpoint} : '/api/v1'; $self->{endpoint} = (defined($self->{option_results}->{endpoint})) ? $self->{option_results}->{endpoint} : '/api/v1';
if ($self->{hostname} eq '') {
$self->{output}->add_option_msg(short_msg => "Need to specify --hostname option.");
$self->{output}->option_exit();
}
return 0; return 0;
} }
@ -106,25 +106,23 @@ sub build_options_for_httplib {
$self->{option_results}->{timeout} = $self->{timeout}; $self->{option_results}->{timeout} = $self->{timeout};
$self->{option_results}->{warning_status} = ''; $self->{option_results}->{warning_status} = '';
$self->{option_results}->{critical_status} = ''; $self->{option_results}->{critical_status} = '';
$self->{option_results}->{unknown_status} = '%{http_code} < 200 or %{http_code} > 400'; $self->{option_results}->{unknown_status} = '%{http_code} < 200 or %{http_code} >= 400';
} }
sub settings { sub settings {
my ($self, %options) = @_; my ($self, %options) = @_;
return if (defined($self->{settings_done}));
$self->build_options_for_httplib(); $self->build_options_for_httplib();
$self->{http}->add_header(key => 'Accept', value => 'application/json'); $self->{http}->add_header(key => 'Accept', value => 'application/json');
$self->{http}->set_options(%{$self->{option_results}}); $self->{http}->set_options(%{$self->{option_results}});
$self->{settings_done} = 1;
} }
sub request_api { sub request_api {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->settings(content_type => 'application/x-www-form-urlencoded'); $self->settings();
$self->{output}->output_add(long_msg => "URL: '" . $self->{proto} . '://' . $self->{hostname} . ':' . $self->{port} .
$options{url_path} . "'", debug => 1);
my $content = $self->{http}->request(%options); my $content = $self->{http}->request(%options);
if (!defined($content) || $content eq '') { if (!defined($content) || $content eq '') {
@ -137,7 +135,6 @@ sub request_api {
$decoded = JSON::XS->new->utf8->decode($content); $decoded = JSON::XS->new->utf8->decode($content);
}; };
if ($@) { if ($@) {
$self->{output}->output_add(long_msg => $content, debug => 1);
$self->{output}->add_option_msg(short_msg => "Cannot decode response (add --debug option to display returned content)"); $self->{output}->add_option_msg(short_msg => "Cannot decode response (add --debug option to display returned content)");
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
@ -163,7 +160,10 @@ sub list_charts {
my ($self, %options) = @_; my ($self, %options) = @_;
my $url_path = $self->{endpoint} . '/charts'; my $url_path = $self->{endpoint} . '/charts';
my $response = $self->request_api(method => 'GET', url_path => $url_path); my $response = $self->request_api(
method => 'GET',
url_path => $url_path
);
return $response; return $response;
} }
@ -172,8 +172,11 @@ sub get_chart_properties {
my ($self, %options) = @_; my ($self, %options) = @_;
my $url_path = $self->{endpoint} . '/chart'; my $url_path = $self->{endpoint} . '/chart';
$url_path .= '?chart=' . $options{chart}; my $response = $self->request_api(
my $response = $self->request_api(method => 'GET', url_path => $url_path); method => 'GET',
url_path => $url_path,
get_param => ['chart=' . $options{chart}]
);
my $filter_info = defined ($options{filter_info}) ? $options{filter_info} : ''; my $filter_info = defined ($options{filter_info}) ? $options{filter_info} : '';
return defined ($filter_info) ? $response->{$filter_info} : $response; return defined ($filter_info) ? $response->{$filter_info} : $response;
@ -183,14 +186,21 @@ sub get_data {
my ($self, %options) = @_; my ($self, %options) = @_;
my $url_path = $self->{endpoint} . '/data'; my $url_path = $self->{endpoint} . '/data';
$url_path .= '?chart=' . $options{chart}; my $get_param = [
$url_path .= '&options=null2zero'; 'chart=' . $options{chart},
$url_path .= '&options=abs' if defined ($options{absolute}); 'options=null2zero',
$url_path .= '&after=-' . $options{after_period}; 'after=-' . $options{after_period},
$url_path .= '&group=' . $options{group}; 'group=' . $options{group},
$url_path .= defined ($options{points}) ? '&points=' . $options{points} : '&points=1'; defined($options{points}) ? 'points=' . $options{points} : 'points=1'
$url_path .= '&dimensions=' . $options{dimensions} if defined ($options{dimensions}); ];
my $response = $self->request_api(method => 'GET', url_path => $url_path),; push @$get_param, 'options=abs' if (defined($options{absolute}));
push @$get_param, 'dimensions=' . $options{dimensions} if (defined($options{dimensions}));
my $response = $self->request_api(
method => 'GET',
url_path => $url_path,
get_param => $get_param
);
return $response; return $response;
} }

View File

@ -24,12 +24,12 @@ use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold catalog_status_calc); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return sprintf('Status: %s, Current state: %s', $self->{result_values}->{status}, $self->{result_values}->{value_string}); return sprintf('status: %s, current state: %s', $self->{result_values}->{status}, $self->{result_values}->{value_string});
} }
sub set_counters { sub set_counters {
@ -43,28 +43,27 @@ sub set_counters {
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
{ label => 'alarms-total', nlabel => 'netdata.alarms.current.total.count', set => { { label => 'alarms-total', nlabel => 'netdata.alarms.current.total.count', set => {
key_values => [ { name => 'total' } ], key_values => [ { name => 'total' } ],
output_template => "%s", output_template => 'total: %s',
perfdatas => [ { value => 'total', template => '%d', min => 0 } ] perfdatas => [ { template => '%d', min => 0 } ]
} }
}, },
{ label => 'alarms-warning', nlabel => 'netdata.alarms.current.warning.count', set => { { label => 'alarms-warning', nlabel => 'netdata.alarms.current.warning.count', set => {
key_values => [ { name => 'warning' } ], key_values => [ { name => 'warning' } ],
output_template => "Warning Alarms : %s", output_template => 'warning: %s',
perfdatas => [ { value => 'warning', template => '%d', min => 0 } ], perfdatas => [ { template => '%d', min => 0 } ]
} }
}, },
{ label => 'alarms-critical', nlabel => 'netdata.alarms.current.critical.count', set => { { label => 'alarms-critical', nlabel => 'netdata.alarms.current.critical.count', set => {
key_values => [ { name => 'critical' } ], key_values => [ { name => 'critical' } ],
output_template => "Critical Alarms : %s", output_template => 'critical: %s',
perfdatas => [ { value => 'critical', template => '%d', min => 0 } ], perfdatas => [ { template => '%d', min => 0 } ]
}
} }
},
]; ];
$self->{maps_counters}->{alarms} = [ $self->{maps_counters}->{alarms} = [
{ label => 'alarm', threshold => 0, set => { { label => 'alarm', threshold => 0, set => {
key_values => [ { name => 'display' }, { name => 'name' }, { name => 'status' }, { name => 'value_string'} ], key_values => [ { name => 'display' }, { name => 'name' }, { name => 'status' }, { name => 'value_string'} ],
closure_custom_calc => \&catalog_status_calc,
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold closure_custom_threshold_check => \&catalog_status_threshold
@ -79,21 +78,16 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'filter-status:s' => { name => 'filter_status' }, 'filter-status:s' => { name => 'filter_status' }
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub prefix_global_output { sub prefix_global_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Total alarms "; return 'Alarms ';
} }
sub prefix_alarm_output { sub prefix_alarm_output {
@ -111,6 +105,7 @@ sub manage_selection {
next if ( defined($self->{option_results}->{filter_status}) next if ( defined($self->{option_results}->{filter_status})
&& $self->{option_results}->{filter_status} ne '' && $self->{option_results}->{filter_status} ne ''
&& $alarm->{status} !~ /$self->{option_results}->{filter_status}/ ); && $alarm->{status} !~ /$self->{option_results}->{filter_status}/ );
$self->{alarms}->{$alarm} = { $self->{alarms}->{$alarm} = {
display => $alarm, display => $alarm,
id => $alarm->{id}, id => $alarm->{id},
@ -120,11 +115,15 @@ sub manage_selection {
value_string => $alarm->{value_string} value_string => $alarm->{value_string}
}; };
$self->{global}->{warning}++ if $alarm->{status} =~ m/WARNING/; $self->{global}->{warning}++ if ($alarm->{status} =~ m/WARNING/);
$self->{global}->{critical}++ if $alarm->{status} =~ m/CRITICAL/; $self->{global}->{critical}++ if ($alarm->{status} =~ m/CRITICAL/);
} }
$self->{global}->{total} = scalar (keys %{$self->{alarms}}); $self->{global} = {
total => scalar(keys %{$self->{alarms}}),
warning => 0,
critical => 0
};
} }
1; 1;

View File

@ -38,23 +38,21 @@ sub set_counters {
key_values => [ { name => 'average' }, { name => 'count' } ], key_values => [ { name => 'average' }, { name => 'count' } ],
output_template => '%.2f %%', output_template => '%.2f %%',
perfdatas => [ perfdatas => [
{ label => 'total_cpu_avg', value => 'average', template => '%.2f', { template => '%.2f', min => 0, max => 100, unit => '%' }
min => 0, max => 100, unit => '%' }, ]
], }
} }
},
]; ];
$self->{maps_counters}->{cpu_results} = [ $self->{maps_counters}->{cpu_results} = [
{ label => 'core', nlabel => 'core.cpu.utilization.percentage', set => { { label => 'core', nlabel => 'core.cpu.utilization.percentage', set => {
key_values => [ { name => 'usage' }, { name => 'display' } ], key_values => [ { name => 'usage' }, { name => 'display' } ],
output_template => 'usage : %.2f %%', output_template => 'usage: %.2f %%',
perfdatas => [ perfdatas => [
{ label => 'cpu', value => 'usage', template => '%.2f', { template => '%.2f', min => 0, max => 100, unit => '%', label_extra_instance => 1 }
min => 0, max => 100, unit => '%', label_extra_instance => 1, instance_use => 'display' }, ]
], }
} }
},
]; ];
} }
@ -77,18 +75,12 @@ sub new {
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'chart-period:s' => { name => 'chart_period', default => '300' }, 'chart-period:s' => { name => 'chart_period', default => '300' },
'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }, 'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -98,21 +90,30 @@ sub manage_selection {
my $cpu_core = 'cpu.cpu' . $i; my $cpu_core = 'cpu.cpu' . $i;
my $result = $options{custom}->get_data( my $result = $options{custom}->get_data(
chart => $cpu_core, chart => $cpu_core,
points => $self->{option_results}->{chart_point},
after_period => $self->{option_results}->{chart_period}, after_period => $self->{option_results}->{chart_period},
group => $self->{option_results}->{chart_statistics} group => $self->{option_results}->{chart_statistics}
); );
foreach my $cpu_value (@{$result->{data}}) {
foreach my $cpu_label (@{$result->{labels}}) { my ($usage, $count) = (0, 0);
$self->{cpu_core}->{$i}->{$cpu_label} = shift @{$cpu_value}; foreach my $data (@{$result->{data}}) {
while (my ($index, $label) = each(@{$result->{labels}})) {
next if ($label eq 'time');
$usage += $data->[$index];
} }
$count++;
} }
if ($count > 0) {
$self->{cpu_results}->{$i} = { $self->{cpu_results}->{$i} = {
display => $cpu_core, display => $i,
usage => $self->{cpu_core}->{$i}->{user} usage => $usage / $count
}; };
$cpu_total_usage += $self->{cpu_results}->{$i}->{usage};
$cpu_total_usage += ($usage / $count);
} }
}
my $avg_cpu = $cpu_total_usage / $cpu_number; my $avg_cpu = $cpu_total_usage / $cpu_number;
$self->{cpu_avg} = { $self->{cpu_avg} = {
average => $avg_cpu, average => $avg_cpu,

View File

@ -18,7 +18,7 @@
# limitations under the License. # limitations under the License.
# #
package apps::monitoring::netdata::restapi::mode::diskusage; package apps::monitoring::netdata::restapi::mode::disks;
use base qw(centreon::plugins::templates::counter); use base qw(centreon::plugins::templates::counter);
@ -32,7 +32,7 @@ sub custom_usage_output {
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used}); my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free}); my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
return sprintf( return sprintf(
'Usage - Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)', 'total: %s used: %s (%.2f%%) free: %s (%.2f%%)',
$total_size_value . " " . $total_size_unit, $total_size_value . " " . $total_size_unit,
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used}, $total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free} $total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free}
@ -50,7 +50,7 @@ sub set_counters {
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'global', type => 0 }, { name => 'global', type => 0 },
{ name => 'diskpath', type => 1, cb_prefix_output => 'prefix_diskpath_output', message_multiple => 'All partitions are ok' }, { name => 'diskpath', type => 1, cb_prefix_output => 'prefix_diskpath_output', message_multiple => 'All partitions are ok' }
]; ];
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
@ -67,7 +67,7 @@ sub set_counters {
key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' }, { name => 'display' } ], key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' }, { name => 'display' } ],
closure_custom_output => $self->can('custom_usage_output'), closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [ perfdatas => [
{ label => 'used', value => 'used', template => '%d', min => 0, max => 'total', { template => '%d', min => 0, max => 'total',
unit => 'B', cast_int => 1, label_extra_instance => 1, instance_use => 'display' } unit => 'B', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
] ]
} }
@ -76,16 +76,16 @@ sub set_counters {
key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' }, { name => 'display' } ], key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' }, { name => 'display' } ],
closure_custom_output => $self->can('custom_usage_output'), closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [ perfdatas => [
{ label => 'free', value => 'free', template => '%d', min => 0, max => 'total', { template => '%d', min => 0, max => 'total',
unit => 'B', cast_int => 1, label_extra_instance => 1, instance_use => 'display' } unit => 'B', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
] ]
} }
}, },
{ label => 'usage-prct', display_ok => 0, nlabel => 'storage.space.usage.percentage', set => { { label => 'usage-prct', display_ok => 0, nlabel => 'storage.space.usage.percentage', set => {
key_values => [ { name => 'prct_used' }, { name => 'display' } ], key_values => [ { name => 'prct_used' }, { name => 'display' } ],
output_template => 'Used : %.2f %%', output_template => 'used: %.2f %%',
perfdatas => [ perfdatas => [
{ label => 'used_prct', value => 'prct_used', template => '%.2f', min => 0, max => 100, { template => '%.2f', min => 0, max => 100,
unit => '%', label_extra_instance => 1, instance_use => 'display' } unit => '%', label_extra_instance => 1, instance_use => 'display' }
] ]
} }
@ -108,11 +108,6 @@ sub new {
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -127,7 +122,6 @@ sub manage_selection {
my $result = $options{custom}->get_data( my $result = $options{custom}->get_data(
chart => $fs, chart => $fs,
dimensions => 'used,avail,reserved_for_root', dimensions => 'used,avail,reserved_for_root',
points => $self->{option_results}->{chart_point},
after_period => $self->{option_results}->{chart_period}, after_period => $self->{option_results}->{chart_period},
group => $self->{option_results}->{chart_statistics} group => $self->{option_results}->{chart_statistics}
); );
@ -146,7 +140,7 @@ sub manage_selection {
} }
} }
my $reserved_space = defined($self->{option_results}->{space_reservation}) ? $self->{fs}->{$fs}->{"reserved for root"} * (1024 ** 3) : '0'; my $reserved_space = defined($self->{option_results}->{space_reservation}) ? $self->{fs}->{$fs}->{'reserved for root'} * (1024 ** 3) : '0';
my $used = $self->{fs}->{$fs}->{used} * (1024 ** 3); my $used = $self->{fs}->{$fs}->{used} * (1024 ** 3);
my $free = $self->{fs}->{$fs}->{avail} * (1024 ** 3); my $free = $self->{fs}->{$fs}->{avail} * (1024 ** 3);
my $total = $used + $free + $reserved_space; my $total = $used + $free + $reserved_space;
@ -169,11 +163,6 @@ sub manage_selection {
}; };
$self->{global}->{count}++; $self->{global}->{count}++;
} }
if (scalar(keys %{$self->{diskpath}}) <= 0) {
$self->{output}->add_option_msg(short_msg => 'Issue with disk path information (see details)');
$self->{output}->option_exit();
}
}; };
1; 1;
@ -237,7 +226,6 @@ Critical threshold on FS free space.
On specific systems, partitions can have reserved space (like ext4 for root). On specific systems, partitions can have reserved space (like ext4 for root).
This option will consider this space in the calculation (like for the 'df' command). This option will consider this space in the calculation (like for the 'df' command).
=back =back
=cut =cut

View File

@ -24,7 +24,7 @@ use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold catalog_status_calc); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
sub custom_metric_perfdata { sub custom_metric_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -34,7 +34,7 @@ sub custom_metric_perfdata {
value => $self->{result_values}->{value}, value => $self->{result_values}->{value},
unit => $self->{result_values}->{unit}, unit => $self->{result_values}->{unit},
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-metric'), warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-metric'),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-metric'), critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-metric')
); );
} }
@ -60,34 +60,22 @@ sub custom_metric_output {
); );
} }
sub custom_metric_calc {
my ($self, %options) = @_;
$self->{result_values}->{value} = $options{new_datas}->{$self->{instance} . '_value'};
$self->{result_values}->{perf_label} = $options{new_datas}->{$self->{instance} . '_perf_label'};
$self->{result_values}->{display} = $options{new_datas}->{$self->{instance} . '_display'};
$self->{result_values}->{unit} = $options{new_datas}->{$self->{instance} . '_unit'};
return 0;
}
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'metric', type => 1, message_multiple => 'All metrics are ok' }, { name => 'metric', type => 1, message_multiple => 'All metrics are ok' }
]; ];
$self->{maps_counters}->{metric} = [ $self->{maps_counters}->{metric} = [
{ label => 'metric', set => { { label => 'metric', set => {
key_values => [ { name => 'value' }, { name => 'perf_label' }, { name => 'display' }, { name => 'unit' } ], key_values => [ { name => 'value' }, { name => 'perf_label' }, { name => 'display' }, { name => 'unit' } ],
closure_custom_calc => $self->can('custom_metric_calc'),
closure_custom_output => $self->can('custom_metric_output'), closure_custom_output => $self->can('custom_metric_output'),
closure_custom_perfdata => $self->can('custom_metric_perfdata'), closure_custom_perfdata => $self->can('custom_metric_perfdata'),
closure_custom_threshold_check => $self->can('custom_metric_threshold'), closure_custom_threshold_check => $self->can('custom_metric_threshold')
} }
} }
]; ];
} }
sub new { sub new {
@ -113,7 +101,6 @@ sub check_options {
$self->{output}->add_option_msg(short_msg => "Missing --chart-name option or value."); $self->{output}->add_option_msg(short_msg => "Missing --chart-name option or value.");
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
} }
sub manage_selection { sub manage_selection {
@ -141,14 +128,15 @@ sub manage_selection {
$self->{metrics}->{$chart_name}->{$chart_label} = shift @{$chart_value}; $self->{metrics}->{$chart_name}->{$chart_label} = shift @{$chart_value};
} }
} }
foreach my $metric (keys %{$self->{metrics}->{$chart_name}}) { foreach my $metric (keys %{$self->{metrics}->{$chart_name}}) {
next if $metric eq 'time'; next if ($metric eq 'time');
foreach my $value (values %{$self->{metrics}->{$chart_name}}) { foreach my $value (values %{$self->{metrics}->{$chart_name}}) {
$self->{metric}->{$metric . '_' . $stat} = { $self->{metric}->{$metric . '_' . $stat} = {
display => $metric . '_' . $stat, display => $metric . '_' . $stat,
value => $value, value => $value,
unit => $unit, unit => $unit,
perf_label => $metric . '_' . $stat, perf_label => $metric . '_' . $stat
}; };
} }
} }

View File

@ -37,11 +37,10 @@ sub set_counters {
key_values => [ { name => 'prct_used' }, { name => 'display' } ], key_values => [ { name => 'prct_used' }, { name => 'display' } ],
output_template => 'Used: %.2f %%', output_template => 'Used: %.2f %%',
perfdatas => [ perfdatas => [
{ label => 'prct_used', value => 'prct_used', template => '%d', { template => '%d', unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'display' },
unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'display' }, ]
], }
} }
},
]; ];
} }
@ -66,11 +65,6 @@ sub new {
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -173,7 +167,6 @@ Critical threshold on FS used Inodes (in %).
On specific systems, partitions can have reserved space/inodes (like ext4 for root). On specific systems, partitions can have reserved space/inodes (like ext4 for root).
This option will consider this space in the calculation (like for the 'df' command). This option will consider this space in the calculation (like for the 'df' command).
=back =back
=cut =cut

View File

@ -18,7 +18,7 @@
# limitations under the License. # limitations under the License.
# #
package apps::monitoring::netdata::restapi::mode::loadaverage; package apps::monitoring::netdata::restapi::mode::load;
use base qw(centreon::plugins::templates::counter); use base qw(centreon::plugins::templates::counter);
@ -28,14 +28,14 @@ use warnings;
sub prefix_load_output { sub prefix_load_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Load average "; return 'Load average ';
} }
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'loadaverage', type => 0, message_separator => ' - ', skipped_code => { -10 => 1 }, cb_prefix_output => 'prefix_load_output' } { name => 'loadaverage', type => 0, skipped_code => { -10 => 1 }, cb_prefix_output => 'prefix_load_output' }
]; ];
$self->{maps_counters}->{loadaverage} = [ $self->{maps_counters}->{loadaverage} = [
@ -43,7 +43,7 @@ sub set_counters {
key_values => [ { name => 'load1' } ], key_values => [ { name => 'load1' } ],
output_template => '%.2f (1m)', output_template => '%.2f (1m)',
perfdatas => [ perfdatas => [
{ label => 'load1', template => '%.2f', min => 0 } { template => '%.2f', min => 0 }
] ]
} }
}, },
@ -51,7 +51,7 @@ sub set_counters {
key_values => [ { name => 'load5' } ], key_values => [ { name => 'load5' } ],
output_template => '%.2f (5m)', output_template => '%.2f (5m)',
perfdatas => [ perfdatas => [
{ label => 'load5', template => '%.2f', min => 0 } { template => '%.2f', min => 0 }
] ]
} }
}, },
@ -59,7 +59,7 @@ sub set_counters {
key_values => [ { name => 'load15' }, { name => 'load1' }, { name => 'load5' } ], key_values => [ { name => 'load15' }, { name => 'load1' }, { name => 'load5' } ],
output_template => '%.2f (15m)', output_template => '%.2f (15m)',
perfdatas => [ perfdatas => [
{ label => 'load15', template => '%.2f', min => 0 } { template => '%.2f', min => 0 }
] ]
} }
} }
@ -79,13 +79,9 @@ sub new {
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $result = $options{custom}->get_data( my $result = $options{custom}->get_data(
chart => 'system.load', chart => 'system.load',
points => $self->{option_results}->{chart_point}, points => $self->{option_results}->{chart_point},

View File

@ -29,7 +29,7 @@ sub custom_usage_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return sprintf( return sprintf(
'Ram Total: %s %s Used (-buffers/cache): %s %s (%.2f%%) Free: %s %s (%.2f%%)', 'Ram total: %s %s used (-buffers/cache): %s %s (%.2f%%) free: %s %s (%.2f%%)',
$self->{perfdata}->change_bytes(value => $self->{result_values}->{total}), $self->{perfdata}->change_bytes(value => $self->{result_values}->{total}),
$self->{perfdata}->change_bytes(value => $self->{result_values}->{used}), $self->{perfdata}->change_bytes(value => $self->{result_values}->{used}),
$self->{result_values}->{prct_used}, $self->{result_values}->{prct_used},
@ -42,7 +42,7 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'ram', type => 0, skipped_code => { -10 => 1 } }, { name => 'ram', type => 0, skipped_code => { -10 => 1 } }
]; ];
$self->{maps_counters}->{ram} = [ $self->{maps_counters}->{ram} = [
@ -50,7 +50,7 @@ sub set_counters {
key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ], key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_usage_output'), closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [ perfdatas => [
{ label => 'used', template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1 } { template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1 }
] ]
} }
}, },
@ -58,15 +58,15 @@ sub set_counters {
key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ], key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_usage_output'), closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [ perfdatas => [
{ label => 'free', template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1 } { template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1 }
] ]
} }
}, },
{ label => 'usage-prct', display_ok => 0, nlabel => 'memory.usage.percentage', set => { { label => 'usage-prct', display_ok => 0, nlabel => 'memory.usage.percentage', set => {
key_values => [ { name => 'prct_used' } ], key_values => [ { name => 'prct_used' } ],
output_template => 'Ram Used : %.2f %%', output_template => 'Ram used : %.2f %%',
perfdatas => [ perfdatas => [
{ label => 'used_prct', template => '%.2f', min => 0, max => 100, unit => '%' } { template => '%.2f', min => 0, max => 100, unit => '%' }
] ]
} }
}, },
@ -75,7 +75,7 @@ sub set_counters {
output_template => 'Buffer: %s %s', output_template => 'Buffer: %s %s',
output_change_bytes => 1, output_change_bytes => 1,
perfdatas => [ perfdatas => [
{ label => 'buffer', template => '%d', min => 0, unit => 'B' } { template => '%d', min => 0, unit => 'B' }
] ]
} }
}, },
@ -84,7 +84,7 @@ sub set_counters {
output_template => 'Cached: %s %s', output_template => 'Cached: %s %s',
output_change_bytes => 1, output_change_bytes => 1,
perfdatas => [ perfdatas => [
{ label => 'cached', template => '%d', min => 0, unit => 'B' } { template => '%d', min => 0, unit => 'B' }
] ]
} }
}, },
@ -93,7 +93,7 @@ sub set_counters {
output_template => 'Shared: %s %s', output_template => 'Shared: %s %s',
output_change_bytes => 1, output_change_bytes => 1,
perfdatas => [ perfdatas => [
{ label => 'shared', template => '%d', min => 0, unit => 'B' } { template => '%d', min => 0, unit => 'B' }
] ]
} }
} }
@ -107,20 +107,15 @@ sub new {
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'chart-period:s' => { name => 'chart_period', default => '300' }, 'chart-period:s' => { name => 'chart_period', default => '300' },
'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }, 'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $result = $options{custom}->get_data( my $result = $options{custom}->get_data(
chart => 'system.ram', chart => 'system.ram',
points => $self->{option_results}->{chart_point}, points => $self->{option_results}->{chart_point},

View File

@ -28,20 +28,21 @@ use warnings;
sub custom_swap_output { sub custom_swap_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf("Swap Total: %s %s Used: %s %s (%.2f%%) Free: %s %s (%.2f%%)", return sprintf(
'Swap total: %s %s used: %s %s (%.2f%%) free: %s %s (%.2f%%)',
$self->{perfdata}->change_bytes(value => $self->{result_values}->{total}), $self->{perfdata}->change_bytes(value => $self->{result_values}->{total}),
$self->{perfdata}->change_bytes(value => $self->{result_values}->{used}), $self->{perfdata}->change_bytes(value => $self->{result_values}->{used}),
$self->{result_values}->{prct_used}, $self->{result_values}->{prct_used},
$self->{perfdata}->change_bytes(value => $self->{result_values}->{free}), $self->{perfdata}->change_bytes(value => $self->{result_values}->{free}),
$self->{result_values}->{prct_free}); $self->{result_values}->{prct_free}
return $msg; );
} }
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'swap', type => 0, message_separator => ' - ', skipped_code => { -10 => 1 } }, { name => 'swap', type => 0, message_separator => ' - ', skipped_code => { -10 => 1 } }
]; ];
$self->{maps_counters}->{swap} = [ $self->{maps_counters}->{swap} = [
@ -49,29 +50,26 @@ sub set_counters {
key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ], key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_swap_output'), closure_custom_output => $self->can('custom_swap_output'),
perfdatas => [ perfdatas => [
{ label => 'used', value => 'used', template => '%d', min => 0, max => 'total', { template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1 }
unit => 'B', cast_int => 1 }, ]
],
} }
}, },
{ label => 'usage-free', display_ok => 0, nlabel => 'swap.free.bytes', set => { { label => 'usage-free', display_ok => 0, nlabel => 'swap.free.bytes', set => {
key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ], key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_swap_output'), closure_custom_output => $self->can('custom_swap_output'),
perfdatas => [ perfdatas => [
{ label => 'free', value => 'free', template => '%d', min => 0, max => 'total', { template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1 }
unit => 'B', cast_int => 1 }, ]
],
} }
}, },
{ label => 'usage-prct', display_ok => 0, nlabel => 'swap.usage.percentage', set => { { label => 'usage-prct', display_ok => 0, nlabel => 'swap.usage.percentage', set => {
key_values => [ { name => 'prct_used' } ], key_values => [ { name => 'prct_used' } ],
output_template => 'Used : %.2f %%', output_template => 'Swap used: %.2f %%',
perfdatas => [ perfdatas => [
{ label => 'used_prct', value => 'prct_used', template => '%.2f', min => 0, max => 100, { template => '%.2f', min => 0, max => 100, unit => '%' }
unit => '%' }, ]
], }
} }
},
]; ];
} }
@ -82,19 +80,15 @@ sub new {
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'chart-period:s' => { name => 'chart_period', default => '300' }, 'chart-period:s' => { name => 'chart_period', default => '300' },
'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }, 'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $result = $options{custom}->get_data( my $result = $options{custom}->get_data(
chart => 'system.swap', chart => 'system.swap',
points => $self->{option_results}->{chart_point}, points => $self->{option_results}->{chart_point},

View File

@ -39,26 +39,24 @@ sub set_counters {
]; ];
$self->{maps_counters}->{interfaces} = [ $self->{maps_counters}->{interfaces} = [
{ label => 'traffic-in', nlabel => 'network.trafficin.bitspersecond', set => { { label => 'traffic-in', nlabel => 'network.traffic.in.bitspersecond', set => {
key_values => [ { name => 'traffic_in' }, { name => 'traffic_out' }, { name => 'display' } ], key_values => [ { name => 'traffic_in' }, { name => 'speed' }, { name => 'display' } ],
output_template => 'Traffic In: %.2f%s/s', output_template => 'traffic in: %.2f%s/s',
output_change_bytes => 2, output_change_bytes => 2,
perfdatas => [ perfdatas => [
{ label => 'traffic_in', value => 'traffic_in', template => '%d', min => 0, max => 'speed', { template => '%d', min => 0, max => 'speed', unit => 'b/s', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
unit => 'b/s', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
] ]
} }
}, },
{ label => 'traffic-out', nlabel => 'network.trafficin.bitspersecond', set => { { label => 'traffic-out', nlabel => 'network.traffic.out.bitspersecond', set => {
key_values => [ { name => 'traffic_out' }, { name => 'traffic_in' }, { name => 'display' } ], key_values => [ { name => 'traffic_out' }, { name => 'speed' }, { name => 'display' } ],
output_template => 'Traffic Out: %.2f%s/s', output_template => 'traffic out: %.2f%s/s',
output_change_bytes => 2, output_change_bytes => 2,
perfdatas => [ perfdatas => [
{ label => 'traffic_out', value => 'traffic_out', template => '%d', min => 0, max => 'speed', { template => '%d', min => 0, max => 'speed', unit => 'b/s', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
unit => 'b/s', cast_int => 1, label_extra_instance => 1, instance_use => 'display' }
] ]
} }
}, }
]; ];
} }
@ -71,30 +69,27 @@ sub new {
'chart-period:s' => { name => 'chart_period', default => '300' }, 'chart-period:s' => { name => 'chart_period', default => '300' },
'chart-statistics:s' => { name => 'chart_statistics', default => 'average' }, 'chart-statistics:s' => { name => 'chart_statistics', default => 'average' },
'interface-name:s' => { name => 'interface_name' }, 'interface-name:s' => { name => 'interface_name' },
'speed:s' => { name => 'speed', default => '1000000000'} 'speed:s' => { name => 'speed' }
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $full_list = $options{custom}->list_charts(); my $full_list = $options{custom}->list_charts();
my $interface_list = [];
foreach my $chart (values %{$full_list->{charts}}) { foreach my $chart (values %{$full_list->{charts}}) {
next if ($chart->{name} !~ '^net\.'); next if ($chart->{name} !~ '^net\.');
push @{$self->{interface_list}}, $chart->{name}; push @$interface_list, { name => $chart->{name}, speed => $chart->{chart_variables}->{nic_speed_max} };
} }
foreach my $interface (@{$self->{interface_list}}) { $self->{interfaces} = {};
foreach my $int (@$interface_list) {
my $result = $options{custom}->get_data( my $result = $options{custom}->get_data(
chart => $interface, chart => $int->{name},
dimensions => 'received,sent', dimensions => 'received,sent',
points => $self->{option_results}->{chart_point}, points => $self->{option_results}->{chart_point},
after_period => $self->{option_results}->{chart_period}, after_period => $self->{option_results}->{chart_period},
@ -102,24 +97,29 @@ sub manage_selection {
absolute => 1 absolute => 1
); );
$interface =~ s/net.//; $int->{name} =~ s/net.//;
next if (defined($self->{option_results}->{interface_name}) && next if (defined($self->{option_results}->{interface_name}) &&
$self->{option_results}->{interface_name} ne '' && $self->{option_results}->{interface_name} ne '' &&
$interface !~ /$self->{option_results}->{interface_name}/ $int->{name} !~ /$self->{option_results}->{interface_name}/
); );
foreach my $interface_value (@{$result->{data}}) { my $count = 0;
foreach my $interface_label (@{$result->{labels}}) { # In Kb/s
$self->{interface}->{$interface}->{$interface_label} = shift @{$interface_value}; my $metrics = { received => 0, sent => 0 };
foreach my $data (@{$result->{data}}) {
while (my ($index, $label) = each(@{$result->{labels}})) {
$metrics->{$label} += $data->[$index];
} }
$count++;
} }
$self->{interfaces}->{$interface} = { $self->{interfaces}->{ $int->{name} } = {
display => $interface, display => $int->{name},
traffic_in => $self->{interface}->{$interface}->{received} * 1000, traffic_in => $metrics->{received} * 1000,
traffic_out => $self->{interface}->{$interface}->{sent} * 1000, traffic_out => $metrics->{sent} * 1000,
speed => $self->{option_results}->{speed} speed => defined($self->{option_results}->{speed}) && $self->{option_results}->{speed} ne '' ?
$self->{option_results}->{speed} : $int->{speed} * 1000 * 1000
}; };
} }
@ -163,8 +163,8 @@ Example: --interface-name='^eth0$'
=item B<--speed> =item B<--speed>
Set interfaces speed in B/s. Set interfaces speed in b/s.
Default: 1000000000 (1GB/s). Default: 1000000000 (1Gb/s).
=item B<--warning-traffic-*> =item B<--warning-traffic-*>

View File

@ -30,20 +30,20 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
%{$self->{modes}} = ( $self->{modes} = {
'alarms' => 'apps::monitoring::netdata::restapi::mode::alarms', 'alarms' => 'apps::monitoring::netdata::restapi::mode::alarms',
'cpu' => 'apps::monitoring::netdata::restapi::mode::cpu', 'cpu' => 'apps::monitoring::netdata::restapi::mode::cpu',
'diskusage' => 'apps::monitoring::netdata::restapi::mode::diskusage', 'disks' => 'apps::monitoring::netdata::restapi::mode::disks',
'get-chart' => 'apps::monitoring::netdata::restapi::mode::getchart', 'get-chart' => 'apps::monitoring::netdata::restapi::mode::getchart',
'inodes' => 'apps::monitoring::netdata::restapi::mode::inodes', 'inodes' => 'apps::monitoring::netdata::restapi::mode::inodes',
'list-charts' => 'apps::monitoring::netdata::restapi::mode::listcharts', 'list-charts' => 'apps::monitoring::netdata::restapi::mode::listcharts',
'loadaverage' => 'apps::monitoring::netdata::restapi::mode::loadaverage', 'load' => 'apps::monitoring::netdata::restapi::mode::load',
'memory' => 'apps::monitoring::netdata::restapi::mode::memory', 'memory' => 'apps::monitoring::netdata::restapi::mode::memory',
'swap' => 'apps::monitoring::netdata::restapi::mode::swap', 'swap' => 'apps::monitoring::netdata::restapi::mode::swap',
'traffic' => 'apps::monitoring::netdata::restapi::mode::traffic' 'traffic' => 'apps::monitoring::netdata::restapi::mode::traffic'
); };
$self->{custom_modes}{restapi} = 'apps::monitoring::netdata::restapi::custom::api'; $self->{custom_modes}->{restapi} = 'apps::monitoring::netdata::restapi::custom::api';
return $self; return $self;
} }