enh(plugin)correct-cache-file-mgmt

This commit is contained in:
Sims24 2020-05-11 22:32:12 +02:00 committed by Lotfi zaouche
parent 18dbd5ed14
commit 045ac667d3
1 changed files with 31 additions and 91 deletions

View File

@ -31,40 +31,42 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'events', cb_prefix_output => 'prefix_module_events', type => 1, message_multiple => 'All event metrics are ok' }, { name => 'events', cb_prefix_output => 'prefix_output_events', type => 1, message_multiple => 'Events metrics are ok' },
{ name => 'miners', cb_prefix_output => 'prefix_module_miners', type => 1, message_multiple => 'All miner metrics are ok' }, { name => 'miners', cb_prefix_output => 'prefix_output_miners', type => 1, message_multiple => 'Miners metrics are ok' },
{ name => 'balances', cb_prefix_output => 'prefix_module_balances', type => 1, message_multiple => 'All balance metrics are ok' }, { name => 'balances', cb_prefix_output => 'prefix_output_balances', type => 1, message_multiple => 'Balances metrics are ok' }
]; ];
$self->{maps_counters}->{events} = [ $self->{maps_counters}->{events} = [
{ label => 'event_frequency', nlabel => 'parity.tracking.event.frequency', set => { { label => 'event_frequency', nlabel => 'parity.tracking.event.persecond', set => {
key_values => [ { name => 'event_frequency' } ], key_values => [ { name => 'event_count', diff => 1 }, { name => 'display' } ],
output_template => "Event's frequency: %d (evt/min)", per_second => 1,
perfdatas => [ output_template => " %.2f (events/s)",
{ label => 'event_frequency', value => 'event_frequency_absolute', template => '%d', min => 0 } perfdatas => [
], { label => 'events', template => '%.2f', value => 'event_count_per_second',
label_extra_instance => 1, instance_use => 'display_absolute' }
],
} }
} }
]; ];
$self->{maps_counters}->{miners} = [ $self->{maps_counters}->{miners} = [
{ label => 'mining_frequency', nlabel => 'parity.tracking.mining.frequency', set => { { label => 'mining_frequency', nlabel => 'parity.tracking.mined.block.persecond', set => {
key_values => [ { name => 'mining_frequency' } ], key_values => [ { name => 'mining_frequency' } ],
output_template => "Mining frequency: %d (block/min)", output_template => " %.2f (blocks/s)",
perfdatas => [ perfdatas => [ instance_use => 'display_absolute', label_extra_instance => 1 ],
{ label => 'mining_frequency', value => 'mining_frequency_absolute', template => '%d', min => 0 }
],
} }
} }
]; ];
$self->{maps_counters}->{balances} = [ $self->{maps_counters}->{balances} = [
{ label => 'balance_fluctuation', nlabel => 'parity.tracking.balances.fluctuation', set => { { label => 'balance_fluctuation', nlabel => 'parity.tracking.balances.variation.persecond', set => {
key_values => [ { name => 'balance_fluctuation' } ], key_values => [ { name => 'balance', diff => 1 } ],
output_template => "Balance fluctuation: %d (diff/min)", per_second => 1,
output_template => " variation: %.2f (diff/sec)",
perfdatas => [ perfdatas => [
{ label => 'balance_fluctuation', value => 'balance_fluctuation_absolute', template => '%d', min => 0 } { label => 'balances', template => '%.2f', value => 'balance_per_second',
], label_extra_instance => 1, instance_use => 'display_absolute' }
],
} }
} }
]; ];
@ -74,24 +76,24 @@ sub set_counters {
sub prefix_output_events { sub prefix_output_events {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Event stats '"; return "Event '" . $options{instance_value}->{display} . "' ";
} }
sub prefix_output_miners { sub prefix_output_miners {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Miner stats '"; return "Miner '" . $options{instance_value}->{display} . "' ";;
} }
sub prefix_output_balances { sub prefix_output_balances {
my ($self, %options) = @_; my ($self, %options) = @_;
return "Balance stats '"; return "Balance '" . $options{instance_value}->{display} . "' ";
} }
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, statefile => 1, force_new_perfdata => 1);
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
@ -109,48 +111,20 @@ sub manage_selection {
my $results = $options{custom}->request_api(url_path => '/tracking'); my $results = $options{custom}->request_api(url_path => '/tracking');
# use Data::Dumper;
# print Dumper($results);
my $res_timestamp = 0;
my $calculated_frequency = 0;
$self->{events} = {}; $self->{events} = {};
$self->{miners} = {}; $self->{miners} = {};
$self->{balances} = {}; $self->{balances} = {};
my $datas = {};
foreach my $event (@{$results->{events}}) { foreach my $event (@{$results->{events}}) {
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' && if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$event->{id} !~ /$self->{option_results}->{filter_name}/) { $event->{id} !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "skipping '" . $event->{id} . "': no matching filter name.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $event->{label} . "': no matching filter name.", debug => 1);
next; next;
} }
my $old_event_timestamp = $self->{statefile_cache}->get(name => 'last_event_timestamp'); #get the id last_event_timestamp $self->{events}->{lc($event->{label})} = { display => lc($event->{label}),
my $old_event_count = $self->{statefile_cache}->get(name => 'last_event_count'); #get the id last_event_count event_count => $event->{count} };
$datas->{$event->{id}}->{last_event_timestamp} = time();
$datas->{$event->{id}}->{last_event_count} = $event->{count};
if ($old_event_count && $old_event_timestamp) {
$calculated_frequency = ($event->{count} - $old_event_count) / (time() - $old_event_timestamp);
$self->{events}->{$event->{id}}->{display} = $event->{label};
$self->{events}->{$event->{id}}->{event_frequency} = $calculated_frequency;
$res_timestamp = $event->{timestamp} == 0 ? '': localtime($event->{timestamp});
if ($event->{count} > 0) {
$self->{output}->output_add(severity => 'OK', long_msg => 'Event ' . $event->{id} . ': Last Tx from "' . $event->{label} . '" (#' . $event->{count} .
') was at ' . $res_timestamp . ' (block #' . $event->{block} . ')' );
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'Event ' . $event->{id} . ': No Tx from "' . $event->{label} . '"');
}
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'Event ' . $event->{id} . ': Building perfdata for "' . $event->{label} . '"...');
}
} }
foreach my $miner (@{$results->{miners}}) { foreach my $miner (@{$results->{miners}}) {
@ -160,51 +134,17 @@ sub manage_selection {
next; next;
} }
my $old_miner_timestamp = $self->{statefile_cache}->get(name => 'last_miner_timestamp'); #get the id last_miner_timestamp
my $old_miner_count = $self->{statefile_cache}->get(name => 'last_miner_count'); #get the id last_miner_count
$datas->{$miner->{id}}->{last_miner_timestamp} = time();
$datas->{$miner->{id}}->{last_miner_count} = $miner->{count};
if ($old_miner_timestamp && $old_miner_timestamp) {
$calculated_frequency = ($miner->{count} - $old_miner_count) / (time() - $old_miner_timestamp);
$self->{miners}->{$miner->{id}}->{display} = $miner->{label};
$self->{miners}->{$miner->{id}}->{mining_frequency} = $calculated_frequency;
$res_timestamp = $miner->{timestamp} == 0 ? '': localtime($miner->{timestamp});
if ($miner->{count} > 0) {
$self->{output}->output_add(severity => 'OK', long_msg => 'Miner ' . $miner->{id} . ': Last block from label "' . $miner->{label} . '" (#' . $miner->{count} .
') was at ' . $res_timestamp . ' (block #' . $miner->{block} . ')' );
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'Miner ' . $miner->{id} . ': No validation from "' . $miner->{label} . '"');
}
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'Miner ' . $miner->{id} . ': Building perfdata for "' . $miner->{label} . '"...');
}
} }
foreach my $balance (@{$results->{balances}}) { foreach my $balance (@{$results->{balances}}) {
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' && if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$balance->{id} !~ /$self->{option_results}->{filter_name}/) { $balance->{id} !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "skipping '" . $balance->{id} . "': no matching filter name.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $balance->{label} . "': no matching filter name.", debug => 1);
next; next;
} }
my $old_balance = $self->{statefile_cache}->get(name => 'last_balance'); #get the id last_balance $self->{balances}->{lc($balance->{label})} = { display => lc($balance->{label}),
balance => $balance->{balance} };
$datas->{$balance->{id}}->{last_balance} = $balance->{balance};
if ($old_balance) {
my $calculated_diff = ($balance->{balance} - $old_balance) / ($old_balance);
$self->{balances}->{$balance->{id}}->{display} = $balance->{label};
$self->{balances}->{$balance->{id}}->{balance} = $calculated_diff;
$self->{output}->output_add(severity => 'OK', long_msg => 'Balance ' . $balance->{id} . ': Balance of "' . $balance->{label} . '" is ' . $balance->{balance} . ' ether' );
} else {
$self->{output}->output_add(severity => 'OK', long_msg => 'Balance ' . $balance->{id} . ': Balance fluctuation of "' . $balance->{label} . '" is being calculated...');
}
} }