This commit is contained in:
garnier-quentin 2019-09-12 17:47:35 +02:00
commit d156ccabcb
8 changed files with 973 additions and 8 deletions

View File

@ -75,11 +75,11 @@ sub run {
$metric !~ /$self->{option_results}->{filter_metrics}/);
foreach my $data (@{$self->{metrics}->{$metric}->{data}}) {
next if (defined($self->{option_results}->{instance}) &&
next if (defined($self->{option_results}->{instance}) && $self->{option_results}->{instance} ne '' &&
!defined($data->{dimensions}->{$self->{option_results}->{instance}}) ||
defined($self->{option_results}->{filter_instance}) && $self->{option_results}->{filter_instance} ne '' &&
$data->{dimensions}->{$self->{option_results}->{instance}} !~ /$self->{option_results}->{filter_instance}/);
next if (defined($self->{option_results}->{subinstance}) &&
next if (defined($self->{option_results}->{subinstance}) && $self->{option_results}->{subinstance} ne '' &&
!defined($data->{dimensions}->{$self->{option_results}->{subinstance}}) ||
defined($self->{option_results}->{filter_subinstance}) && $self->{option_results}->{filter_subinstance} ne '' &&
$data->{dimensions}->{$self->{option_results}->{subinstance}} !~ /$self->{option_results}->{filter_subinstance}/);
@ -87,14 +87,14 @@ sub run {
my $label = $metric;
$label =~ s/_/./g if (defined($self->{option_results}->{new_perfdata}));
$label = $data->{dimensions}->{$self->{option_results}->{instance}} . '#' . $label
if (defined($self->{option_results}->{instance}) &&
if (defined($self->{option_results}->{instance}) && $self->{option_results}->{instance} ne '' &&
defined($data->{dimensions}->{$self->{option_results}->{instance}}) &&
!defined($self->{option_results}->{subinstance}));
$label = $data->{dimensions}->{$self->{option_results}->{instance}} . '~' .
$data->{dimensions}->{$self->{option_results}->{subinstance}} . '#' . $label
if (defined($self->{option_results}->{instance}) &&
if (defined($self->{option_results}->{instance}) && $self->{option_results}->{instance} ne '' &&
defined($data->{dimensions}->{$self->{option_results}->{instance}}) &&
defined($self->{option_results}->{subinstance}) &&
defined($self->{option_results}->{subinstance}) && $self->{option_results}->{subinstance} ne '' &&
defined($data->{dimensions}->{$self->{option_results}->{subinstance}}));
$label =~ s/'//g;
@ -147,7 +147,7 @@ Examples:
# perl centreon_plugins.pl --plugin=apps::monitoring::openmetrics::plugin --mode=scrape-metrics
--custommode=web --hostname=10.2.3.4 --port=9100 --verbose --filter-metrics='node_cpu_seconds_total'
--instance='cpu' --subinstance='mode' --filter-subinstance='idle'
--instance='cpu' --subinstance='mode' --filter-subinstance='mode'
# perl centreon_plugins.pl --plugin=apps::monitoring::openmetrics::plugin --mode=scrape-metrics
--custommode=file --command-options='/tmp/metrics' --filter-metrics='cpu' --verbose

View File

@ -1,11 +1,14 @@
2019-09-XX Quentin Garnier <qgarnier@centreon.com>
* Plugin added: Warp10
* Plugin added: Warp10 Sensision
* Plugin added: OpenMetrics
* Plugin added: AWS API Gateway Api
* Plugin added: AWS Kinesis Api
* Plugin added: Hanwha Camera SNMP
* Plugin added: Perle IDS SNMP
* Plugin added: Scom Rest API
* Plugin added: Wazuh Rest API
* Plugin added: Zoom Rest API
* Plugin added: VMWare vcsa Rest API
* Plugin added: VMWare VCSA Rest API
* Plugin added: EMC Unisphere Rest API
* Plugin added: Nitram UPS SNMP
* Plugin added: Quanta.io Rest API
@ -13,7 +16,12 @@
* Enhancement: [cisco/standard/snmp] add err disable interfaces
* Enhancement: [oracle] add container option
* Enhancement: [snmp_standard] 'memory' add option for redhat
* Enhancement: [nsclient] handle new rest api
* Enhancement: [aruba/standard] enhance modes to use ap name
* Enhancement: [azure] allow multiple metrics in monitor getmetrics mode
* Enhancement: [aws/paws] add proxyurl option
* Break: [ucopia] modes refactoring
* Break: [aws] metrics forced to new format for billing, cloudfront, elb, ec2, lambda breaks thresholds
* Fix: Ctrl+F "Fix" on commits page
2019-07-04 Quentin Garnier <qgarnier@centreon.com>

View File

@ -0,0 +1,197 @@
#
# Copyright 2019 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 cloud::aws::apigateway::mode::latency;
use base qw(centreon::plugins::templates::counter);
use strict;
use warnings;
my %metrics_mapping = (
'Latency' => {
'output' => 'Client Latency',
'output_unit' => 'ms',
'perfdata_unit' => 'ms',
'label' => 'client-latency',
'nlabel' => 'apigateway.client.latency.milliseconds'
},
'IntegrationLatency' => {
'output' => 'Integration Latency',
'output_unit' => 'ms',
'perfdata_unit' => 'ms',
'label' => 'backend-latency',
'nlabel' => 'apigateway.backend.latency.milliseconds'
},
);
sub prefix_metric_output {
my ($self, %options) = @_;
return ucfirst("'" . $options{instance_value}->{display} . "' ");
}
sub prefix_statistics_output {
my ($self, %options) = @_;
return "Statistic: '" . $options{instance_value}->{display} . "' ";
}
sub long_output {
my ($self, %options) = @_;
return "Checking " . $options{instance_value}->{display} . "' ";
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'metrics', type => 3, cb_prefix_output => 'prefix_metric_output', cb_long_output => 'long_output',
message_multiple => 'All API latency metrics are ok', indent_long_output => ' ',
group => [
{ name => 'statistics', display_long => 1, cb_prefix_output => 'prefix_statistics_output',
message_multiple => 'All metrics are ok', type => 1, skipped_code => { -10 => 1 } },
]
}
];
foreach my $metric (keys %metrics_mapping) {
my $entry = {
label => $metrics_mapping{$metric}->{label},
nlabel => $metrics_mapping{$metric}->{nlabel},
set => {
key_values => [ { name => $metric }, { name => 'display' } ],
output_template => $metrics_mapping{$metric}->{output} . ': %.2f ' . $metrics_mapping{$metric}->{output_unit},
perfdatas => [
{ value => $metric . '_absolute', template => '%.2f', label_extra_instance => 1,
perfdata_unit => $metrics_mapping{$metric}->{perfdata_unit} }
],
}
};
push @{$self->{maps_counters}->{statistics}}, $entry;
}
}
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, force_new_perfdata => 1, %options);
bless $self, $class;
$options{options}->add_options(arguments => {
"api-name:s@" => { name => 'api_name' },
"filter-metric:s" => { name => 'filter_metric' },
});
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
foreach my $instance (@{$self->{option_results}->{api_name}}) {
if ($instance ne '') {
push @{$self->{aws_instance}}, $instance;
}
}
$self->{aws_timeframe} = defined($self->{option_results}->{timeframe}) ? $self->{option_results}->{timeframe} : 600;
$self->{aws_period} = defined($self->{option_results}->{period}) ? $self->{option_results}->{period} : 60;
$self->{aws_statistics} = ['Average'];
if (defined($self->{option_results}->{statistic})) {
$self->{aws_statistics} = [];
foreach my $stat (@{$self->{option_results}->{statistic}}) {
if ($stat ne '') {
push @{$self->{aws_statistics}}, ucfirst(lc($stat));
}
}
}
foreach my $metric (keys %metrics_mapping) {
next if (defined($self->{option_results}->{filter_metric}) && $self->{option_results}->{filter_metric} ne ''
&& $metric !~ /$self->{option_results}->{filter_metric}/);
push @{$self->{aws_metrics}}, $metric;
}
}
sub manage_selection {
my ($self, %options) = @_;
my %metric_results;
foreach my $instance (@{$self->{aws_instance}}) {
$metric_results{$instance} = $options{custom}->cloudwatch_get_metrics(
region => $self->{option_results}->{region},
namespace => 'AWS/ApiGateway',
dimensions => [ { Name => 'ApiName', Value => $instance } ],
metrics => $self->{aws_metrics},
statistics => $self->{aws_statistics},
timeframe => $self->{aws_timeframe},
period => $self->{aws_period},
);
foreach my $metric (@{$self->{aws_metrics}}) {
foreach my $statistic (@{$self->{aws_statistics}}) {
next if (!defined($metric_results{$instance}->{$metric}->{lc($statistic)})
&& !defined($self->{option_results}->{zeroed}));
$self->{metrics}->{$instance}->{display} = $instance;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{display} = $statistic;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{$metric} =
defined($metric_results{$instance}->{$metric}->{lc($statistic)}) ?
$metric_results{$instance}->{$metric}->{lc($statistic)} : 0;
}
}
}
if (scalar(keys %{$self->{metrics}}) <= 0) {
$self->{output}->add_option_msg(short_msg => 'No metrics. Check your options or use --zeroed option to set 0 on undefined values');
$self->{output}->option_exit();
}
}
1;
__END__
=head1 MODE
Check metrics related to ApiGateway latencies
Default statistic: 'sum'
=over 8
=item B<--api-name>
Set the API name (Required) (Can be multiple).
=item B<--filter-metric>
Filter metrics (Can be: 'Latency', 'IntegrationLatency')
=item B<--warning-*> B<--critical-*>
Thresholds warning
star substitution possibilities: client-latency, backend-latency
=back
=cut

View File

@ -0,0 +1,200 @@
#
# Copyright 2019 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 cloud::aws::apigateway::mode::requests;
use base qw(centreon::plugins::templates::counter);
use strict;
use warnings;
my %metrics_mapping = (
'Count' => {
'output' => 'Client Requests',
'label' => 'requests-client',
'nlabel' => 'apigateway.requests.client.count'
},
'4XXError' => {
'output' => 'HTTP 4XX Errors',
'label' => 'requests-errors-4xx',
'nlabel' => 'apigateway.requests.errors.4xx.count'
},
'5XXError' => {
'output' => 'HTTP 5XX Errors',
'label' => 'requests-errors-5xx',
'nlabel' => 'apigateway.requests.errors.5xx.count'
},
);
sub prefix_metric_output {
my ($self, %options) = @_;
return " '" . $options{instance_value}->{display} . "' ";
}
sub prefix_statistics_output {
my ($self, %options) = @_;
return "Statistic '" . $options{instance_value}->{display} . "' Metrics ";
}
sub long_output {
my ($self, %options) = @_;
return "Checking '" . $options{instance_value}->{display} . "' ";
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'metrics', type => 3, cb_prefix_output => 'prefix_metric_output', cb_long_output => 'long_output',
message_multiple => 'All requests metrics are ok', indent_long_output => ' ',
group => [
{ name => 'statistics', display_long => 1, cb_prefix_output => 'prefix_statistics_output',
message_multiple => 'All requests are ok', type => 1, skipped_code => { -10 => 1 } },
]
}
];
foreach my $metric (keys %metrics_mapping) {
my $entry = {
label => $metrics_mapping{$metric}->{label},
nlabel => $metrics_mapping{$metric}->{nlabel},
set => {
key_values => [ { name => $metric }, { name => 'display' } ],
output_template => $metrics_mapping{$metric}->{output} . ': %.2f',
perfdatas => [
{ value => $metric . '_absolute', template => '%.2f', label_extra_instance => 1 }
],
}
};
push @{$self->{maps_counters}->{statistics}}, $entry;
}
}
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, force_new_perfdata => 1, %options);
bless $self, $class;
$options{options}->add_options(arguments => {
"api-name:s@" => { name => 'api_name' },
"filter-metric:s" => { name => 'filter_metric' },
});
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
foreach my $instance (@{$self->{option_results}->{api_name}}) {
if ($instance ne '') {
push @{$self->{aws_instance}}, $instance;
}
}
$self->{aws_timeframe} = defined($self->{option_results}->{timeframe}) ? $self->{option_results}->{timeframe} : 600;
$self->{aws_period} = defined($self->{option_results}->{period}) ? $self->{option_results}->{period} : 60;
$self->{aws_statistics} = ['Sum'];
if (defined($self->{option_results}->{statistic})) {
$self->{aws_statistics} = [];
foreach my $stat (@{$self->{option_results}->{statistic}}) {
if ($stat ne '') {
push @{$self->{aws_statistics}}, ucfirst(lc($stat));
}
}
}
foreach my $metric (keys %metrics_mapping) {
next if (defined($self->{option_results}->{filter_metric}) && $self->{option_results}->{filter_metric} ne ''
&& $metric !~ /$self->{option_results}->{filter_metric}/);
push @{$self->{aws_metrics}}, $metric;
}
}
sub manage_selection {
my ($self, %options) = @_;
my %metric_results;
foreach my $instance (@{$self->{aws_instance}}) {
$metric_results{$instance} = $options{custom}->cloudwatch_get_metrics(
region => $self->{option_results}->{region},
namespace => 'AWS/ApiGateway',
dimensions => [ { Name => 'ApiName', Value => $instance } ],
metrics => $self->{aws_metrics},
statistics => $self->{aws_statistics},
timeframe => $self->{aws_timeframe},
period => $self->{aws_period},
);
foreach my $metric (@{$self->{aws_metrics}}) {
foreach my $statistic (@{$self->{aws_statistics}}) {
next if (!defined($metric_results{$instance}->{$metric}->{lc($statistic)})
&& !defined($self->{option_results}->{zeroed}));
$self->{metrics}->{$instance}->{display} = $instance;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{display} = $statistic;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{$metric} =
defined($metric_results{$instance}->{$metric}->{lc($statistic)}) ?
$metric_results{$instance}->{$metric}->{lc($statistic)} : 0;
}
}
}
if (scalar(keys %{$self->{metrics}}) <= 0) {
$self->{output}->add_option_msg(short_msg => 'No metrics. Check your options or use --zeroed option to set 0 on undefined values');
$self->{output}->option_exit();
}
}
1;
__END__
=head1 MODE
Check metrics related to ApiGateway requests
Default statistic: 'sum'
=over 8
=item B<--api-name>
Set the api name (Required) (Can be multiple).
=item B<--filter-metric>
Filter metrics (Can be: 'Count', '4XXError', '5XXError')
=item B<--warning-*> B<--critical-*>
Thresholds warning
star substitusion possibilities: requests-client,
requests-errors-4xx, requests-errors-5xx
=back
=cut

View File

@ -0,0 +1,51 @@
#
# Copyright 2019 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 cloud::aws::apigateway::plugin;
use strict;
use warnings;
use base qw(centreon::plugins::script_custom);
sub new {
my ( $class, %options ) = @_;
my $self = $class->SUPER::new( package => __PACKAGE__, %options );
bless $self, $class;
$self->{version} = '0.1';
%{ $self->{modes} } = (
'requests' => 'cloud::aws::apigateway::mode::requests',
'latency' => 'cloud::aws::apigateway::mode::latency',
);
$self->{custom_modes}{paws} = 'cloud::aws::custom::paws';
$self->{custom_modes}{awscli} = 'cloud::aws::custom::awscli';
return $self;
}
1;
__END__
=head1 PLUGIN DESCRIPTION
Check Amazon API Gateway (AmazonApiGateway).
=cut

View File

@ -0,0 +1,241 @@
#
# Copyright 2019 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 cloud::aws::kinesis::mode::recordsstats;
use base qw(centreon::plugins::templates::counter);
use strict;
use warnings;
my %metrics_mapping = (
'GetRecords.IteratorAgeMilliseconds' => {
'output' => 'Get Records Iterator Age',
'label' => 'records-get-iteratorage',
'nlabel' => 'kinesis.stream.records.get.iteratorage.milliseconds',
'perf_unit' => 'ms',
'change_bytes' => '0',
'stats' => { 'sum' => 'false' }
},
'GetRecords.Bytes' => {
'output' => 'Get Records Bytes',
'label' => 'records-get-volume',
'nlabel' => 'kinesis.stream.records.get.volume.bytes',
'perf_unit' => 'B',
'change_bytes' => '2',
},
'GetRecords.Latency' => {
'output' => 'Get Records Latency',
'label' => 'records-get-latency',
'nlabel' => 'kinesis.stream.records.get.latency.milliseconds',
'perf_unit' => 'ms',
'change_bytes' => '0',
'stats' => { 'sum' => 'false' }
},
'GetRecords.Success' => {
'output' => 'Get Records Success',
'label' => 'records-get-success',
'nlabel' => 'kinesis.stream.records.get.success.count',
'perf_unit' => '',
'change_bytes' => '0',
'stats' => { 'average' => 'false' }
},
'PutRecord.Latency' => {
'output' => 'Put Records Latency',
'label' => 'records-put-latency',
'nlabel' => 'kinesis.stream.records.put.latency.milliseconds',
'perf_unit' => 'ms',
'change_bytes' => '0',
'stats' => { 'sum' => 'false' }
},
'PutRecord.Bytes' => {
'output' => 'Put Records Bytes',
'label' => 'records-put-volume',
'nlabel' => 'kinesis.stream.records.put.volume.bytes',
'perf_unit' => 'B',
'change_bytes' => '2'
},
'PutRecord.Success' => {
'output' => 'Put Records Success',
'label' => 'records-put-success',
'nlabel' => 'kinesis.stream.records.put.success.count',
'perf_unit' => '',
'change_bytes' => '0',
'stats' => { 'average' => 'false' }
},
);
sub prefix_metric_output {
my ($self, %options) = @_;
return " '" . $options{instance_value}->{display} . "' ";
}
sub prefix_statistics_output {
my ($self, %options) = @_;
return "Statistic '" . $options{instance_value}->{display} . "' Metrics ";
}
sub long_output {
my ($self, %options) = @_;
return "Checking'" . $options{instance_value}->{display} . "' ";
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'metrics', type => 3, cb_prefix_output => 'prefix_metric_output', cb_long_output => 'long_output',
message_multiple => 'All records to streams metrics are ok', indent_long_output => ' ',
group => [
{ name => 'statistics', display_long => 1, cb_prefix_output => 'prefix_statistics_output',
message_multiple => 'All records to streams metrics are ok', type => 1, skipped_code => { -10 => 1 } },
]
}
];
foreach my $metric (keys %metrics_mapping) {
my $entry = {
label => $metrics_mapping{$metric}->{label},
nlabel => $metrics_mapping{$metric}->{nlabel},
set => {
key_values => [ { name => $metric }, { name => 'display' } ],
output_template => ($metrics_mapping{$metric}->{change_bytes} != 0) ? $metrics_mapping{$metric}->{output} . ': %.2f %s' : $metrics_mapping{$metric}->{output} . ': %.2f',
change_bytes => $metrics_mapping{$metric}->{output_change_bytes},
perfdatas => [
{ value => $metric . '_absolute', template => '%.2f', label_extra_instance => 1, unit => $metrics_mapping{$metric}->{perf_unit} }
],
}
};
push @{$self->{maps_counters}->{statistics}}, $entry;
}
}
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, force_new_perfdata => 1, %options);
bless $self, $class;
$options{options}->add_options(arguments => {
"stream-name:s@" => { name => 'stream_name' },
"filter-metric:s" => { name => 'filter_metric' },
});
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
foreach my $instance (@{$self->{option_results}->{stream_name}}) {
if ($instance ne '') {
push @{$self->{aws_instance}}, $instance;
}
}
$self->{aws_timeframe} = defined($self->{option_results}->{timeframe}) ? $self->{option_results}->{timeframe} : 600;
$self->{aws_period} = defined($self->{option_results}->{period}) ? $self->{option_results}->{period} : 60;
$self->{aws_statistics} = ['Average','Sum'];
if (defined($self->{option_results}->{statistic})) {
$self->{aws_statistics} = [];
foreach my $stat (@{$self->{option_results}->{statistic}}) {
if ($stat ne '') {
push @{$self->{aws_statistics}}, ucfirst(lc($stat));
}
}
}
foreach my $metric (keys %metrics_mapping) {
next if (defined($self->{option_results}->{filter_metric}) && $self->{option_results}->{filter_metric} ne ''
&& $metric !~ /$self->{option_results}->{filter_metric}/);
push @{$self->{aws_metrics}}, $metric;
}
}
sub manage_selection {
my ($self, %options) = @_;
my %metric_results;
foreach my $instance (@{$self->{aws_instance}}) {
$metric_results{$instance} = $options{custom}->cloudwatch_get_metrics(
region => $self->{option_results}->{region},
namespace => 'AWS/Kinesis',
dimensions => [ { Name => 'StreamName', Value => $instance } ],
metrics => $self->{aws_metrics},
statistics => $self->{aws_statistics},
timeframe => $self->{aws_timeframe},
period => $self->{aws_period},
);
foreach my $metric (@{$self->{aws_metrics}}) {
foreach my $statistic (@{$self->{aws_statistics}}) {
next if (!defined($metric_results{$instance}->{$metric}->{lc($statistic)})
&& !defined($self->{option_results}->{zeroed})
|| defined($metrics_mapping{$metric}->{stats}->{lc($statistic)})
&& $metrics_mapping{$metric}->{stats}->{lc($statistic)} eq "false");
$self->{metrics}->{$instance}->{display} = $instance;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{display} = $statistic;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{$metric} =
defined($metric_results{$instance}->{$metric}->{lc($statistic)}) ?
$metric_results{$instance}->{$metric}->{lc($statistic)} : 0;
}
}
}
if (scalar(keys %{$self->{metrics}}) <= 0) {
$self->{output}->add_option_msg(short_msg => 'No metrics. Check your options or use --zeroed option to set 0 on undefined values');
$self->{output}->option_exit();
}
}
1;
__END__
=head1 MODE
Check metrics about records statistics in Kinesis streams.
=over 8
=item B<--name>
Set the stream name (Required) (Can be multiple).
=item B<--filter-metric>
Filter metrics (Can be: 'GetRecords.IteratorAgeMilliseconds', 'GetRecords.Bytes', )
=item B<--warning-*> B<--critical-*>
Thresholds warning
can be: 'records-get-iteratorage', 'records-get-volume',
'records-get-latency', 'records-get-success',
'records-put-volume', 'records-put-latency',
'records-get-success',
=back
=cut

View File

@ -0,0 +1,217 @@
#
# Copyright 2019 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 cloud::aws::kinesis::mode::streams;
use base qw(centreon::plugins::templates::counter);
use strict;
use warnings;
my %metrics_mapping = (
'IncomingBytes' => {
'output' => 'Incoming Bytes',
'label' => 'incoming-volume',
'nlabel' => 'kinesis.stream.incoming.volume.bytes',
'perf_unit' => 'B',
'change_bytes' => '2'
},
'IncomingRecords' => {
'output' => 'Incoming Records',
'label' => 'incoming-records',
'nlabel' => 'kinesis.stream.incoming.records.count',
'perf_unit' => '',
'change_bytes' => '0',
'stats' => { 'average' => 'false' }
},
'OutgoingBytes' => {
'output' => 'Outgoing Bytes',
'label' => 'outgoing-volume',
'nlabel' => 'kinesis.stream.outgoing.volume.bytes',
'perf_unit' => 'B',
'change_bytes' => '2'
},
'OutgoingRecords' => {
'output' => 'Outgoing Records',
'label' => 'outgoing-records',
'nlabel' => 'kinesis.stream.outgoing.records.count',
'perf_unit' => '',
'change_bytes' => '0',
'stats' => { 'average' => 'false' }
},
);
sub prefix_metric_output {
my ($self, %options) = @_;
return " '" . $options{instance_value}->{display} . "' ";
}
sub prefix_statistics_output {
my ($self, %options) = @_;
return "Statistic '" . $options{instance_value}->{display} . "' Metrics ";
}
sub long_output {
my ($self, %options) = @_;
return "Checking'" . $options{instance_value}->{display} . "' ";
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'metrics', type => 3, cb_prefix_output => 'prefix_metric_output', cb_long_output => 'long_output',
message_multiple => 'All stream metrics are ok', indent_long_output => ' ',
group => [
{ name => 'statistics', display_long => 1, cb_prefix_output => 'prefix_statistics_output',
message_multiple => 'All stream metrics are ok', type => 1, skipped_code => { -10 => 1 } },
]
}
];
foreach my $metric (keys %metrics_mapping) {
my $entry = {
label => $metrics_mapping{$metric}->{label},
nlabel => $metrics_mapping{$metric}->{nlabel},
set => {
key_values => [ { name => $metric }, { name => 'display' } ],
output_template => ($metrics_mapping{$metric}->{change_bytes} != 0) ? $metrics_mapping{$metric}->{output} . ': %.2f %s' : $metrics_mapping{$metric}->{output} . ': %.2f',
change_bytes => $metrics_mapping{$metric}->{output_change_bytes},
perfdatas => [
{ value => $metric . '_absolute', template => '%.2f', label_extra_instance => 1, unit => $metrics_mapping{$metric}->{perf_unit} }
],
}
};
push @{$self->{maps_counters}->{statistics}}, $entry;
}
}
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, force_new_perfdata => 1, %options);
bless $self, $class;
$options{options}->add_options(arguments => {
"stream-name:s@" => { name => 'stream_name' },
"filter-metric:s" => { name => 'filter_metric' },
});
return $self;
}
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
foreach my $instance (@{$self->{option_results}->{stream_name}}) {
if ($instance ne '') {
push @{$self->{aws_instance}}, $instance;
}
}
$self->{aws_timeframe} = defined($self->{option_results}->{timeframe}) ? $self->{option_results}->{timeframe} : 600;
$self->{aws_period} = defined($self->{option_results}->{period}) ? $self->{option_results}->{period} : 60;
$self->{aws_statistics} = ['Average','Sum'];
if (defined($self->{option_results}->{statistic})) {
$self->{aws_statistics} = [];
foreach my $stat (@{$self->{option_results}->{statistic}}) {
if ($stat ne '') {
push @{$self->{aws_statistics}}, ucfirst(lc($stat));
}
}
}
foreach my $metric (keys %metrics_mapping) {
next if (defined($self->{option_results}->{filter_metric}) && $self->{option_results}->{filter_metric} ne ''
&& $metric !~ /$self->{option_results}->{filter_metric}/);
push @{$self->{aws_metrics}}, $metric;
}
}
sub manage_selection {
my ($self, %options) = @_;
my %metric_results;
foreach my $instance (@{$self->{aws_instance}}) {
$metric_results{$instance} = $options{custom}->cloudwatch_get_metrics(
region => $self->{option_results}->{region},
namespace => 'AWS/Kinesis',
dimensions => [ { Name => 'StreamName', Value => $instance } ],
metrics => $self->{aws_metrics},
statistics => $self->{aws_statistics},
timeframe => $self->{aws_timeframe},
period => $self->{aws_period},
);
foreach my $metric (@{$self->{aws_metrics}}) {
foreach my $statistic (@{$self->{aws_statistics}}) {
next if (!defined($metric_results{$instance}->{$metric}->{lc($statistic)})
&& !defined($self->{option_results}->{zeroed})
|| defined($metrics_mapping{$metric}->{stats}->{lc($statistic)})
&& $metrics_mapping{$metric}->{stats}->{lc($statistic)} eq "false");
$self->{metrics}->{$instance}->{display} = $instance;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{display} = $statistic;
$self->{metrics}->{$instance}->{statistics}->{lc($statistic)}->{$metric} =
defined($metric_results{$instance}->{$metric}->{lc($statistic)}) ?
$metric_results{$instance}->{$metric}->{lc($statistic)} : 0;
}
}
}
if (scalar(keys %{$self->{metrics}}) <= 0) {
$self->{output}->add_option_msg(short_msg => 'No metrics. Check your options or use --zeroed option to set 0 on undefined values');
$self->{output}->option_exit();
}
}
1;
__END__
=head1 MODE
Check metrics for Kinesis streams.
note: Outgoing* metrics are only available when enhanced stats are enabled (paid metrics)
=over 8
=item B<--stream-name>
Set the stream name (Required) (Can be multiple).
=item B<--filter-metric>
Filter metrics (Can be: 'IncomingBytes', 'IncomingRecords',
'OutgoingBytes', 'OutgoingRecords')
=item B<--warning-*> B<--critical-*>
Thresholds warning
can be: 'incoming-bytes', 'incoming-records',
'outgoing-volume', 'outgoing-volume'.
=back
=cut

View File

@ -0,0 +1,51 @@
#
# Copyright 2019 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 cloud::aws::kinesis::plugin;
use strict;
use warnings;
use base qw(centreon::plugins::script_custom);
sub new {
my ( $class, %options ) = @_;
my $self = $class->SUPER::new( package => __PACKAGE__, %options );
bless $self, $class;
$self->{version} = '0.1';
%{ $self->{modes} } = (
'streams' => 'cloud::aws::kinesis::mode::streams',
'records-stats' => 'cloud::aws::kinesis::mode::recordsstats'
);
$self->{custom_modes}{paws} = 'cloud::aws::custom::paws';
$self->{custom_modes}{awscli} = 'cloud::aws::custom::awscli';
return $self;
}
1;
__END__
=head1 PLUGIN DESCRIPTION
Check Amazon Kinesis Stream related metrics (AWS/Kinesis Service).
=cut