custom outputs update

This commit is contained in:
Lotfi zaouche 2020-05-21 22:10:32 +00:00
parent aa6afc913a
commit 4233b497ef
6 changed files with 332 additions and 207 deletions

View File

@ -39,7 +39,7 @@ sub set_counters {
key_values => [ { name => 'disk_free' } ], key_values => [ { name => 'disk_free' } ],
output_template => "Disk free: %d ", output_template => "Disk free: %d ",
perfdatas => [ perfdatas => [
{ label => 'disk_free', value => 'disk_free_absolute', template => '%d', min => 0 } { label => 'disk_free', value => 'disk_free', template => '%d', min => 0 }
], ],
} }
}, },
@ -47,7 +47,7 @@ sub set_counters {
key_values => [ { name => 'disk_available' } ], key_values => [ { name => 'disk_available' } ],
output_template => "Disk available: %d ", output_template => "Disk available: %d ",
perfdatas => [ perfdatas => [
{ label => 'disk_available', value => 'disk_available_absolute', template => '%d', min => 0 } { label => 'disk_available', value => 'disk_available', template => '%d', min => 0 }
], ],
} }
}, },
@ -55,7 +55,7 @@ sub set_counters {
key_values => [ { name => 'disk_size' } ], key_values => [ { name => 'disk_size' } ],
output_template => "Disk size: %d ", output_template => "Disk size: %d ",
perfdatas => [ perfdatas => [
{ label => 'disk_size', value => 'disk_size_absolute', template => '%d', min => 0 } { label => 'disk_size', value => 'disk_size', template => '%d', min => 0 }
], ],
} }
}, },
@ -63,7 +63,7 @@ sub set_counters {
key_values => [ { name => 'disk_used' } ], key_values => [ { name => 'disk_used' } ],
output_template => "Disk used: %d ", output_template => "Disk used: %d ",
perfdatas => [ perfdatas => [
{ label => 'disk_used', value => 'disk_used_absolute', template => '%d', min => 0 } { label => 'disk_used', value => 'disk_used', template => '%d', min => 0 }
], ],
} }
}, },
@ -71,7 +71,7 @@ sub set_counters {
key_values => [ { name => 'disk_usage' } ], key_values => [ { name => 'disk_usage' } ],
output_template => "Disk usage: %d %%", output_template => "Disk usage: %d %%",
perfdatas => [ perfdatas => [
{ label => 'disk_usage', value => 'disk_usage_absolute', template => '%d', min => 0 } { label => 'disk_usage', value => 'disk_usage', template => '%d', min => 0 }
], ],
} }
}, },
@ -79,7 +79,7 @@ sub set_counters {
key_values => [ { name => 'blockchain_dir' } ], key_values => [ { name => 'blockchain_dir' } ],
output_template => "Blockchain directory: %d", output_template => "Blockchain directory: %d",
perfdatas => [ perfdatas => [
{ label => 'blockchain_dir', value => 'blockchain_dir_absolute', template => '%d', min => 0 } { label => 'blockchain_dir', value => 'blockchain_dir', template => '%d', min => 0 }
], ],
} }
} }

View File

@ -1,148 +1,198 @@
# #
# Copyright 2020 Centreon (http://www.centreon.com/) # Copyright 2020 Centreon (http://www.centreon.com/)
# #
# Centreon is a full-fledged industry-strength solution that meets # Centreon is a full-fledged industry-strength solution that meets
# the needs in IT infrastructure and application monitoring for # the needs in IT infrastructure and application monitoring for
# service performance. # service performance.
# #
# Licensed under the Apache License, Version 2.0 (the "License"); # Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License. # you may not use this file except in compliance with the License.
# You may obtain a copy of the License at # You may obtain a copy of the License at
# #
# http://www.apache.org/licenses/LICENSE-2.0 # http://www.apache.org/licenses/LICENSE-2.0
# #
# Unless required by applicable law or agreed to in writing, software # Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, # distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
package blockchain::parity::ethpoller::mode::stats; package blockchain::parity::ethpoller::mode::stats;
use base qw(centreon::plugins::templates::counter); use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use bigint; use bigint;
use Digest::MD5 qw(md5_hex); use Time::Seconds;
use Digest::MD5 qw(md5_hex);
sub set_counters {
my ($self, %options) = @_; sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'block', cb_prefix_output => 'prefix_output_block', type => 0 }, $self->{maps_counters_type} = [
{ name => 'transaction', cb_prefix_output => 'prefix_output_transaction', type => 0 } { name => 'block', cb_prefix_output => 'prefix_output_block', type => 0 },
]; { name => 'transaction', cb_prefix_output => 'prefix_output_transaction', type => 0 },
{ name => 'fork', cb_prefix_output => 'prefix_output_fork', type => 0 }
$self->{maps_counters}->{block} = [ ];
{ label => 'block-frequency', nlabel => 'parity.stats.block.perminute', set => {
key_values => [ { name => 'block_count', per_minute => 1 }, { name => 'last_block' }, { name => 'last_block_ts' } ], $self->{maps_counters}->{block} = [
per_minute => 1, { label => 'block-frequency', nlabel => 'parity.stats.block.perminute', set => {
closure_custom_output => $self->can('custom_block_output'), key_values => [ { name => 'block_count', per_minute => 1 }, { name => 'last_block' }, { name => 'last_block_ts' } ],
perfdatas => [ closure_custom_output => $self->can('custom_block_output'),
{ label => 'block', value => 'block_count', template => '%.2f' } perfdatas => [
], { label => 'block', value => 'block_count', template => '%.2f' }
} ],
} }
]; }
];
$self->{maps_counters}->{transaction} = [
{ label => 'transaction_frequency', nlabel => 'parity.stats.transaction.perminute', set => { $self->{maps_counters}->{transaction} = [
key_values => [ { name => 'transaction_count', per_minute => 1 } ], { label => 'transaction-frequency', nlabel => 'parity.stats.transaction.perminute', set => {
per_minute => 1, key_values => [ { name => 'transaction_count', per_minute => 1 }, { name => 'last_transaction' }, { name => 'last_transaction_ts' } ],
output_template => "Transaction frequency: %.2f (tx/min)", closure_custom_output => $self->can('custom_transaction_output'),
perfdatas => [ perfdatas => [
{ label => 'transaction', value => 'transaction_count_per_minute', template => '%.2f' } { label => 'transaction', value => 'transaction_count', template => '%.2f' }
], ],
} }
} }
]; ];
}
$self->{maps_counters}->{fork} = [
sub custom_block_output { { label => 'fork-frequency', nlabel => 'parity.stats.fork.perminute', set => {
my ($self, %options) = @_; key_values => [ { name => 'fork_count', per_minute => 1 }, { name => 'last_fork' }, { name => 'last_fork_ts' } ],
closure_custom_output => $self->can('custom_fork_output'),
return sprintf( perfdatas => [
"Count: '%.2f', Last block ID: '%s', Last block timestamp '%s' ", { label => 'fork', value => 'fork_count', template => '%.2f' }
$self->{result_values}->{block_count}, ],
$self->{result_values}->{last_block}, }
$self->{result_values}->{last_block_ts} }
); ];
} }
sub custom_block_output {
sub prefix_output_block { my ($self, %options) = @_;
my ($self, %options) = @_;
if (0 eq $self->{result_values}->{block_count}) {
return "Block stats '"; return sprintf("No block yet...");
} } else {
my $time_elapsed = time() - $self->{result_values}->{last_block_ts};
sub prefix_output_fork { my $t = Time::Seconds->new($time_elapsed);
my ($self, %options) = @_;
return sprintf(
return "Fork stats '"; "Block frequency: '%.2f/min', Last block (#%s) was %s ago",
} $self->{result_values}->{block_count},
$self->{result_values}->{last_block},
sub prefix_output_transaction { $t->pretty
my ($self, %options) = @_; );
}
return "Transaction stats '"; }
}
sub custom_transaction_output {
sub new { my ($self, %options) = @_;
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1, statefile => 1); if (0 eq $self->{result_values}->{transaction_count}) {
bless $self, $class; return sprintf("No transaction yet...");
} else {
$options{options}->add_options(arguments => { my $time_elapsed = time() - $self->{result_values}->{last_transaction_ts};
"filter-name:s" => { name => 'filter_name' }, my $t = Time::Seconds->new($time_elapsed);
});
return sprintf(
return $self; "Transaction frequency: '%.2f/min', Last transaction (#%s) was %s ago",
} $self->{result_values}->{transaction_count},
$self->{result_values}->{last_transaction},
sub manage_selection { $t->pretty
my ($self, %options) = @_; );
}
$self->{cache_name} = "parity_ethpoller_" . $self->{mode} . '_' . (defined($self->{option_results}->{hostname}) ? $self->{option_results}->{hostname} : 'me') . '_' . }
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
sub custom_fork_output {
my $result = $options{custom}->request_api(url_path => '/stats'); my ($self, %options) = @_;
my $last_block = $result->{block}->{count}; if (0 eq $self->{result_values}->{fork_count}) {
my $last_block_timestamp = (defined($result->{block}->{timestamp}) && $result->{block}->{timestamp} != 0) ? return sprintf("No fork occurred yet...");
localtime($result->{block}->{timestamp}) : } else {
'NONE'; my $time_elapsed = time() - $self->{result_values}->{last_fork_ts};
my $t = Time::Seconds->new($time_elapsed);
$self->{block} = { block_count => $result->{block}->{count},
last_block => $last_block, return sprintf(
last_block_ts => $last_block_timestamp }; "Fork frequency: '%.2f/min', Last fork (#%s) was %s ago",
$self->{result_values}->{fork_count},
$self->{transaction} = { transaction_count => $result->{transaction}->{count} }; $self->{result_values}->{last_fork},
$t->pretty
if ($result->{transaction}->{count} > 0) { );
my $tx_timestamp = $result->{transaction}->{timestamp} == 0 ? '' : localtime($result->{transaction}->{timestamp}); }
$self->{output}->output_add(severity => 'OK', long_msg => 'Last transaction (#' . $result->{transaction}->{count} . ') was on ' . $tx_timestamp); }
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'No transaction...');
} sub prefix_output_block {
my ($self, %options) = @_;
if ($result->{transaction}->{count} > 0) {
my $fork_timestamp = $result->{fork}->{timestamp} == 0 ? '' : localtime($result->{fork}->{timestamp}); return "Block stats '";
$self->{output}->output_add(severity => 'OK', long_msg => 'Last fork (#' . $result->{fork}->{count} . ') was on ' . $fork_timestamp); }
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'No fork occurence...'); sub prefix_output_fork {
} my ($self, %options) = @_;
}
return "Fork stats '";
1; }
__END__ sub prefix_output_transaction {
my ($self, %options) = @_;
=head1 MODE
return "Transaction stats '";
Check Parity eth-poller for stats }
=cut sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1, statefile => 1);
bless $self, $class;
$options{options}->add_options(arguments => {
"filter-name:s" => { name => 'filter_name' },
});
return $self;
}
sub manage_selection {
my ($self, %options) = @_;
$self->{cache_name} = "parity_ethpoller_" . $self->{mode} . '_' . (defined($self->{option_results}->{hostname}) ? $self->{option_results}->{hostname} : 'me') . '_' .
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
my $result = $options{custom}->request_api(url_path => '/stats');
my $last_block_timestamp = (defined($result->{block}->{timestamp}) && $result->{block}->{timestamp} != 0) ?
$result->{block}->{timestamp} :
'NONE';
my $last_transaction_timestamp = (defined($result->{transaction}->{timestamp}) && $result->{transaction}->{timestamp} != 0) ?
$result->{transaction}->{timestamp} :
'NONE';
my $last_fork_timestamp = (defined($result->{fork}->{timestamp}) && $result->{fork}->{timestamp} != 0) ?
$result->{fork}->{timestamp} :
'NONE';
$self->{block} = { block_count => $result->{block}->{count},
last_block => $result->{block}->{count},
last_block_ts => $last_block_timestamp };
$self->{transaction} = { transaction_count => $result->{transaction}->{count},
last_transaction => $result->{transaction}->{count},
last_transaction_ts => $last_transaction_timestamp };
$self->{fork} = { fork_count => $result->{fork}->{count},
last_fork => $result->{fork}->{count},
last_fork_ts => $last_fork_timestamp };
}
1;
__END__
=head1 MODE
Check Parity eth-poller for stats
=cut

View File

@ -25,6 +25,7 @@ use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use bigint; use bigint;
use Time::Seconds;
use Digest::MD5 qw(md5_hex); use Digest::MD5 qw(md5_hex);
sub set_counters { sub set_counters {
@ -33,13 +34,14 @@ sub set_counters {
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'events', cb_prefix_output => 'prefix_output_events', type => 1, message_multiple => 'Events metrics are ok' }, { name => 'events', cb_prefix_output => 'prefix_output_events', type => 1, message_multiple => 'Events metrics are ok' },
{ name => 'mining', cb_prefix_output => 'prefix_output_mining', type => 1, message_multiple => 'Mining metrics are ok' }, { name => 'mining', cb_prefix_output => 'prefix_output_mining', type => 1, message_multiple => 'Mining metrics are ok' },
{ name => 'balance', cb_prefix_output => 'prefix_output_balance', type => 1, message_multiple => 'Balances metrics are ok' } { name => 'balance', cb_prefix_output => 'prefix_output_balances', type => 1, message_multiple => 'Balances metrics are ok' }
]; ];
$self->{maps_counters}->{events} = [ $self->{maps_counters}->{events} = [
{ label => 'events-frequency', nlabel => 'parity.tracking.events.perminute', set => { { label => 'events-frequency', nlabel => 'parity.tracking.events.perminute', set => {
key_values => [ { name => 'events_count', per_minute => 1 }, { name => 'display' } ], key_values => [ { name => 'events_count', per_minute => 1 }, { name => 'display' },
output_template => " %.2f (events/min)", { name => 'last_event' }, { name => 'last_event_block' }, { name => 'last_event_ts' } ],
closure_custom_output => $self->can('custom_event_output'),
perfdatas => [ perfdatas => [
{ template => '%.2f', label_extra_instance => 1, instance_use => 'display' } { template => '%.2f', label_extra_instance => 1, instance_use => 'display' }
] ]
@ -49,8 +51,9 @@ sub set_counters {
$self->{maps_counters}->{mining} = [ $self->{maps_counters}->{mining} = [
{ label => 'mining-frequency', nlabel => 'parity.tracking.mined.block.perminute', set => { { label => 'mining-frequency', nlabel => 'parity.tracking.mined.block.perminute', set => {
key_values => [ { name => 'mining_count', per_minute => 1 }, { name => 'display' } ], key_values => [ { name => 'mining_count', per_minute => 1 }, { name => 'display' },
output_template => " %.2f (blocks/min)", , { name => 'last_mining' }, { name => 'last_mining_block' }, { name => 'last_mining_ts' } ],
closure_custom_output => $self->can('custom_miner_output'),
perfdatas => [ perfdatas => [
{ template => '%.2f', label_extra_instance => 1, instance_use => 'display' } { template => '%.2f', label_extra_instance => 1, instance_use => 'display' }
] ]
@ -59,17 +62,27 @@ sub set_counters {
]; ];
$self->{maps_counters}->{balance} = [ $self->{maps_counters}->{balance} = [
{ label => 'balance-fluctuation', nlabel => 'parity.tracking.balance.variation.perminute', set => { { label => 'balance-fluctuation-prct', nlabel => 'parity.tracking.balances.fluctuation', display_ok => 0, set => {
key_values => [ { name => 'balance', per_minute => 1 }, { name => 'display' } ], key_values => [],
output_template => " variation: %.2f (diff/min)", manual_keys => 1,
closure_custom_calc => $self->can('custom_prct_calc'),
closure_custom_output => $self->can('custom_balance_output'),
threshold_use => 'balance_fluctuation_prct',
perfdatas => [ perfdatas => [
{ template => '%.2f', label_extra_instance => 1, instance_use => 'display' } { value => 'balance_fluctuation_prct', template => '%.2f', unit => '%',
] min => 0, label_extra_instance => 1, instance_use => 'display' }
],
} }
} }
]; ];
} }
sub prefix_output_balances {
my ($self, %options) = @_;
return "*Balance* '" . $options{instance_value}->{display} . "' ";
}
sub prefix_output_events { sub prefix_output_events {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -79,13 +92,68 @@ sub prefix_output_events {
sub prefix_output_mining { sub prefix_output_mining {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Miner '" . $options{instance_value}->{display} . "' ";; return "Miner '" . $options{instance_value}->{display} . "' ";
} }
sub prefix_output_balance { sub custom_balance_output {
my ($self, %options) = @_;
return sprintf(
"Balance: %s ether, Last fluctuation: %.2f ",
$self->{result_values}->{balance},
$self->{result_values}->{balance_fluctuation_prct}
);
}
sub custom_prct_calc {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Balance '" . $options{instance_value}->{display} . "' "; $self->{result_values}->{display} = $options{new_datas}->{$self->{instance} . '_display'};
$self->{result_values}->{balance} = $options{new_datas}->{$self->{instance} . '_balance'};
$self->{result_values}->{balance_old} = $options{old_datas}->{$self->{instance} . '_balance'};
$self->{result_values}->{balance_fluctuation_prct} = (defined($self->{result_values}->{balance_old}) && $self->{result_values}->{balance_old} != 0) ?
($self->{result_values}->{balance} - $self->{result_values}->{balance_old}) /
$self->{result_values}->{balance_old} * 100 : 0;
return 0;
}
sub custom_event_output {
my ($self, %options) = @_;
if (0 eq $self->{result_values}->{last_event}) {
return sprintf("No event yet...");
} else {
my $time_elapsed = time() - $self->{result_values}->{last_event_ts};
my $t = Time::Seconds->new($time_elapsed);
return sprintf(
"Event frequency: %.2f/min, Last event (#%s) was %s ago in block #%s",
$self->{result_values}->{event_count},
$self->{result_values}->{last_event},
$t->pretty,
$self->{result_values}->{last_event_block}
);
}
}
sub custom_miner_output {
my ($self, %options) = @_;
if (0 eq $self->{result_values}->{last_mining}) {
return sprintf("No validation yet...");
} else {
my $time_elapsed = time() - $self->{result_values}->{last_mining_ts};
my $t = Time::Seconds->new($time_elapsed);
return sprintf(
"Mining frequency: %.2f/min, Last validation (#%s) was %s ago for block #%s",
$self->{result_values}->{mining_count},
$self->{result_values}->{last_mining},
$t->pretty,
$self->{result_values}->{last_mining_block}
);
}
} }
sub new { sub new {
@ -119,9 +187,14 @@ sub manage_selection {
next; next;
} }
my $last_event_timestamp = (defined($event->{timestamp}) && $event->{timestamp} != 0) ? $event->{timestamp} : 'NONE';
$self->{events}->{lc($event->{label})} = { $self->{events}->{lc($event->{label})} = {
display => lc($event->{label}), display => lc($event->{label}),
events_count => $event->{count} events_count => $event->{count},
last_event => $event->{count},
last_event_block => $event->{block},
last_event_ts => $last_event_timestamp
}; };
} }
@ -132,9 +205,14 @@ sub manage_selection {
next; next;
} }
my $last_mining_timestamp = (defined($miner->{timestamp}) && $miner->{timestamp} != 0) ? $miner->{timestamp} : 'NONE';
$self->{mining}->{lc($miner->{label})} = { $self->{mining}->{lc($miner->{label})} = {
display => lc($miner->{label}), display => lc($miner->{label}),
mining_count => $miner->{count} mining_count => $miner->{count},
last_mining => $miner->{count},
last_mining_block => $miner->{block},
last_mining_ts => $last_mining_timestamp
}; };
} }
@ -150,6 +228,7 @@ sub manage_selection {
balance => $balance->{balance} balance => $balance->{balance}
}; };
} }
} }
1; 1;
@ -160,4 +239,4 @@ __END__
Check Parity eth-poller for events, miners and balances tracking Check Parity eth-poller for events, miners and balances tracking
=cut =cut

View File

@ -51,7 +51,7 @@ sub set_counters {
key_values => [ { name => 'sync_status' } ], key_values => [ { name => 'sync_status' } ],
output_template => "Syncing: %d %% ", output_template => "Syncing: %d %% ",
perfdatas => [ perfdatas => [
{ label => 'sync_status', value => 'sync_status_absolute', template => '%d', min => 0 } { label => 'sync_status', value => 'sync_status', template => '%d', min => 0 }
], ],
} }
} }
@ -62,7 +62,7 @@ sub set_counters {
key_values => [ { name => 'gas_price' } ], key_values => [ { name => 'gas_price' } ],
output_template => "The gas price is: %d wei ", output_template => "The gas price is: %d wei ",
perfdatas => [ perfdatas => [
{ label => 'gas_price', value => 'gas_price_absolute', template => '%d', min => 0 } { label => 'gas_price', value => 'gas_price', template => '%d', min => 0 }
], ],
} }
}, },
@ -70,7 +70,7 @@ sub set_counters {
key_values => [ { name => 'gas_used' } ], key_values => [ { name => 'gas_used' } ],
output_template => "The gas used is: %d", output_template => "The gas used is: %d",
perfdatas => [ perfdatas => [
{ label => 'gas_used', value => 'gas_used_absolute', template => '%d', min => 0 } { label => 'gas_used', value => 'gas_used', template => '%d', min => 0 }
], ],
} }
}, },
@ -78,7 +78,7 @@ sub set_counters {
key_values => [ { name => 'gas_limit' } ], key_values => [ { name => 'gas_limit' } ],
output_template => "The gas limit is: %d", output_template => "The gas limit is: %d",
perfdatas => [ perfdatas => [
{ label => 'gas_limit', value => 'gas_limit_absolute', template => '%d', min => 0 } { label => 'gas_limit', value => 'gas_limit', template => '%d', min => 0 }
], ],
} }
} }
@ -87,9 +87,9 @@ sub set_counters {
$self->{maps_counters}->{block} = [ $self->{maps_counters}->{block} = [
{ label => 'block_size', nlabel => 'parity.eth.block.size', set => { { label => 'block_size', nlabel => 'parity.eth.block.size', set => {
key_values => [ { name => 'block_size' } ], key_values => [ { name => 'block_size' } ],
output_template => "Most recent block size: %d ", output_template => "Block size: %d ",
perfdatas => [ perfdatas => [
{ label => 'block_size', value => 'block_size_absolute', template => '%d', min => 0 } { label => 'block_size', value => 'block_size', template => '%d', min => 0 }
], ],
} }
}, },
@ -97,7 +97,7 @@ sub set_counters {
key_values => [ { name => 'block_usage' } ], key_values => [ { name => 'block_usage' } ],
output_template => "Block usage: %d %%", output_template => "Block usage: %d %%",
perfdatas => [ perfdatas => [
{ label => 'block_usage', value => 'block_usage_absolute', template => '%d', min => 0 } { label => 'block_usage', value => 'block_usage', template => '%d', min => 0 }
], ],
} }
}, },
@ -105,7 +105,7 @@ sub set_counters {
key_values => [ { name => 'block_transactions' } ], key_values => [ { name => 'block_transactions' } ],
output_template => "Block transactions number: %d ", output_template => "Block transactions number: %d ",
perfdatas => [ perfdatas => [
{ label => 'block_transactions', value => 'block_transactions_absolute', template => '%d', min => 0 } { label => 'block_transactions', value => 'block_transactions', template => '%d', min => 0 }
], ],
} }
}, },
@ -113,23 +113,15 @@ sub set_counters {
key_values => [ { name => 'block_gas' } ], key_values => [ { name => 'block_gas' } ],
output_template => "Block gas: %d ", output_template => "Block gas: %d ",
perfdatas => [ perfdatas => [
{ label => 'block_gas', value => 'block_gas_absolute', template => '%d', min => 0 } { label => 'block_gas', value => 'block_gas', template => '%d', min => 0 }
], ],
} }
}, },
# { label => 'block_difficulty', nlabel => 'parity.eth.block.difficulty', set => {
# key_values => [ { name => 'block_difficulty' } ],
# output_template => "Block difficulty: %f ",
# perfdatas => [
# { label => 'block_difficulty', value => 'block_difficulty_absolute', template => '%f', min => 0 }
# ],
# }
# },
{ label => 'block_uncles', nlabel => 'parity.eth.block.uncles', set => { { label => 'block_uncles', nlabel => 'parity.eth.block.uncles', set => {
key_values => [ { name => 'block_uncles' } ], key_values => [ { name => 'block_uncles' } ],
output_template => "Block uncles: %d ", output_template => "Block uncles: %d ",
perfdatas => [ perfdatas => [
{ label => 'block_uncles', value => 'block_uncles_absolute', template => '%d', min => 0 } { label => 'block_uncles', value => 'block_uncles', template => '%d', min => 0 }
], ],
} }
}, },
@ -224,14 +216,14 @@ sub manage_selection {
block_uncles => scalar(@{$$result[5]->{result}->{uncles}}), block_uncles => scalar(@{$$result[5]->{result}->{uncles}}),
block_transactions => scalar(@{$$result[5]->{result}->{transactions}})}; block_transactions => scalar(@{$$result[5]->{result}->{transactions}})};
$self->{output}->output_add(severity => 'OK', long_msg => 'Node status: [is_mining: ' . @{$result}[0]->{result} . '] [sync_start: ' . $res_startingBlock . # $self->{output}->output_add(severity => 'OK', long_msg => 'Node status: [is_mining: ' . @{$result}[0]->{result} . '] [sync_start: ' . $res_startingBlock .
'] [sync_current: ' . $res_currentBlock . '] [sync_highest: ' . $res_highestBlock . '] [sync: ' . $res_sync . '%]'); # '] [sync_current: ' . $res_currentBlock . '] [sync_highest: ' . $res_highestBlock . '] [sync: ' . $res_sync . '%]');
$self->{output}->output_add(severity => 'OK', long_msg => 'Client: [coinbase: ' . @{$result}[1]->{result} . ']'); # $self->{output}->output_add(severity => 'OK', long_msg => 'Client: [coinbase: ' . @{$result}[1]->{result} . ']');
$self->{output}->output_add(severity => 'OK', long_msg => 'Global: [hashrate: ' . hex(@{$result}[3]->{result}) . # $self->{output}->output_add(severity => 'OK', long_msg => 'Global: [hashrate: ' . hex(@{$result}[3]->{result}) .
'] [block_number: ' . (defined @{$result}[4]->{result} ? hex(@{$result}[4]->{result}) : 0) . ']'); # '] [block_number: ' . (defined @{$result}[4]->{result} ? hex(@{$result}[4]->{result}) : 0) . ']');
$self->{output}->output_add(severity => 'OK', long_msg => 'Last block: [block_time: ' . $res_block_time . '] [block_gas_limit: ' . hex(@{$result}[5]->{result}->{gasLimit}) . # $self->{output}->output_add(severity => 'OK', long_msg => 'Last block: [block_time: ' . $res_block_time . '] [block_gas_limit: ' . hex(@{$result}[5]->{result}->{gasLimit}) .
'] [block_miner: ' . @{$result}[5]->{result}->{miner} . '] [block_hash: ' . @{$result}[5]->{result}->{hash} . # '] [block_miner: ' . @{$result}[5]->{result}->{miner} . '] [block_hash: ' . @{$result}[5]->{result}->{hash} .
'] [last_block_number: ' . hex(@{$result}[5]->{result}->{number}) . ']'); # '] [last_block_number: ' . hex(@{$result}[5]->{result}->{number}) . ']');
} }

View File

@ -48,7 +48,7 @@ sub set_counters {
key_values => [ { name => 'peers' } ], key_values => [ { name => 'peers' } ],
output_template => "connected peers: %s ", output_template => "connected peers: %s ",
perfdatas => [ perfdatas => [
{ label => 'peer_count', value => 'peers_absolute', template => '%d', min => 0 } { label => 'peer_count', value => 'peers', template => '%d', min => 0 }
], ],
} }
}, },

View File

@ -36,7 +36,7 @@ sub set_counters {
]; ];
$self->{maps_counters}->{mempool} = [ $self->{maps_counters}->{mempool} = [
{ label => 'tx_pending', nlabel => 'parity.pending.transactions', set => { { label => 'mempool_tx_pending', nlabel => 'parity.pending.transactions', set => {
key_values => [ { name => 'tx_pending' } ], key_values => [ { name => 'tx_pending' } ],
output_template => "Pending transactions: %d", output_template => "Pending transactions: %d",
perfdatas => [ perfdatas => [
@ -65,7 +65,7 @@ sub set_counters {
$self->{maps_counters}->{peers} = [ $self->{maps_counters}->{peers} = [
{ label => 'peers_connected', nlabel => 'parity.peers.connected', set => { { label => 'peers_connected', nlabel => 'parity.peers.connected', set => {
key_values => [ { name => 'peers_connected' } ], key_values => [ { name => 'peers_connected' } ],
output_template => "Peers connected: %d", output_template => "Connected peers: %d",
perfdatas => [ perfdatas => [
{ label => 'peers_connected', value => 'peers_connected', template => '%d', min => 0 } { label => 'peers_connected', value => 'peers_connected', template => '%d', min => 0 }
], ],
@ -81,7 +81,7 @@ sub set_counters {
}, },
{ label => 'peers_usage', nlabel => 'parity.peers.usage', set => { { label => 'peers_usage', nlabel => 'parity.peers.usage', set => {
key_values => [ { name => 'peers_usage' } ], key_values => [ { name => 'peers_usage' } ],
output_template => "Mempool usage: %d %% ", output_template => "Peers usage: %d %% ",
perfdatas => [ perfdatas => [
{ label => 'peers_usage', value => 'peers_usage', template => '%d', min => 0 } { label => 'peers_usage', value => 'peers_usage', template => '%d', min => 0 }
], ],
@ -91,6 +91,16 @@ sub set_counters {
} }
sub custom_peers_output {
my ($self, %options) = @_;
return sprintf(
"Connected peers: %d / %d",
$self->{result_values}->{peers_connected},
$self->{result_values}->{peers_limit}
);
}
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1, statefile => 1); my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1, statefile => 1);
@ -162,19 +172,13 @@ sub manage_selection {
# use Data::Dumper; # use Data::Dumper;
# print Dumper($result); # print Dumper($result);
$self->{output}->output_add(long_msg => "Config: [chain name: " . @{$result}[1]->{result} . "] [parity version: " . $res_parity_version . "] [version_hash: "
. @{$result}[0]->{result}->{hash} . "]", severity => 'OK');
$self->{output}->output_add(long_msg => "Network: [peers_connected: " . @{$result}[3]->{result}->{connected} . "] [peers_max: " . @{$result}[3]->{result}->{max} . "] [peers: "
. scalar(@{$$result[3]->{result}->{peers}}) . "]", severity => 'OK');
$self->{output}->output_add(long_msg => "Node: [node_name: " . @{$result}[5]->{result} . "] [enode: " . @{$result}[4]->{result} . "]", severity => 'OK');
$self->{output}->output_add(long_msg => "Mempool: [pending_transactions: " . scalar(@{$$result[2]->{result}}) . "] [transactions_limit: " . @{$result}[6]->{result} . "]", severity => 'OK');
$self->{mempool} = { mempool_usage => scalar(@{$$result[2]->{result}}) / @{$result}[6]->{result} * 100, #TO CHECK division entière $self->{mempool} = { mempool_usage => scalar(@{$$result[2]->{result}}) / @{$result}[6]->{result} * 100, #TO CHECK division entière
mempool_size => @{$result}[6]->{result}, mempool_size => @{$result}[6]->{result},
tx_pending => scalar(@{$$result[2]->{result}}) }; tx_pending => scalar(@{$$result[2]->{result}}) };
$self->{peers} = { peers_usage => @{$result}[3]->{result}->{connected} / @{$result}[3]->{result}->{max} * 100, #TO CHECK division entière $self->{peers} = { peers_usage => @{$result}[3]->{result}->{connected} / @{$result}[3]->{result}->{max} * 100, #TO CHECK division entière
peers_max => @{$result}[3]->{result}->{max}, peers_max => @{$result}[3]->{result}->{max},
peers_limit => @{$result}[3]->{result}->{max},
peers_connected => @{$result}[3]->{result}->{connected} }; peers_connected => @{$result}[3]->{result}->{connected} };
} }