From 7f7a7e3b8bf44f741782b285b7c564c8d1452a16 Mon Sep 17 00:00:00 2001 From: qgarnier Date: Sun, 27 Jul 2014 15:46:54 +0200 Subject: [PATCH] Some work on value (need some tests) --- centreon/plugins/class/bytes.pm | 190 --------------- centreon/plugins/values.pm | 235 +++++++++++++++++++ storage/hp/p2000/xmlapi/mode/volumesstats.pm | 44 +++- 3 files changed, 269 insertions(+), 200 deletions(-) delete mode 100644 centreon/plugins/class/bytes.pm create mode 100644 centreon/plugins/values.pm diff --git a/centreon/plugins/class/bytes.pm b/centreon/plugins/class/bytes.pm deleted file mode 100644 index 49d6fea3a..000000000 --- a/centreon/plugins/class/bytes.pm +++ /dev/null @@ -1,190 +0,0 @@ -################################################################################ -# Copyright 2005-2013 MERETHIS -# Centreon is developped by : Julien Mathis and Romain Le Merlus under -# GPL Licence 2.0. -# -# This program is free software; you can redistribute it and/or modify it under -# the terms of the GNU General Public License as published by the Free Software -# Foundation ; either version 2 of the License. -# -# This program is distributed in the hope that it will be useful, but WITHOUT ANY -# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. See the GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License along with -# this program; if not, see . -# -# Linking this program statically or dynamically with other modules is making a -# combined work based on this program. Thus, the terms and conditions of the GNU -# General Public License cover the whole combination. -# -# As a special exception, the copyright holders of this program give MERETHIS -# permission to link this program with independent modules to produce an executable, -# regardless of the license terms of these independent modules, and to copy and -# distribute the resulting executable under terms of MERETHIS choice, provided that -# MERETHIS also meet, for each linked independent module, the terms and conditions -# of the license of that module. An independent module is a module which is not -# derived from this program. If you modify this program, you may extend this -# exception to your version of the program, but you are not obliged to do so. If you -# do not wish to do so, delete this exception statement from your version. -# -# For more information : contact@centreon.com -# Authors : Quentin Garnier -# -#################################################################################### - -package centreon::plugins::class::bytes; - -use strict; -use warnings; - -sub new { - my ($class, %options) = @_; - my $self = {}; - bless $self, $class; - - $self->{statefile} = $options{statefile}; - $self->{output} = $options{output}; - $self->{perfdata} = $options{perfdata}; - $self->{label} = $options{label}; - - $self->{perfdata_template} = '%s'; - $self->{perfdata_use} = 'absolute'; - $self->{perfdata_extra_instance} = 1; - - $self->{output_template} = $self->{label} . ': %s %s'; - $self->{output_use} = ['absolute']; - $self->{output_change_bytes} = 1; - - $self->{absolute_unit} = 'B'; - $self->{per_second_unit} = 'B'; - - $self->{per_second} = 0; - $self->{last_timestamp} = undef; - - $self->{result_values} = {}; - - return $self; -} - -sub init { - my ($self, %options) = @_; - - if (($self->{perfdata}->threshold_validate(label => 'warning-' . $self->{label}, value => $self->{option_results}->{'warning-' . $self->{label}})) == 0) { - $self->{output}->add_option_msg(short_msg => "Wrong warning-" . $self->{label} . " threshold '" . $self->{option_results}->{'warning-' . $self->{label}} . "'."); - $self->{output}->option_exit(); - } - if (($self->{perfdata}->threshold_validate(label => 'critical-' . $self->{label}, value => $self->{option_results}->{'critical-' . $self->{label}})) == 0) { - $self->{output}->add_option_msg(short_msg => "Wrong critical-" . $self->{label} . " threshold '" . $self->{option_results}->{'warning-' . $self->{label}} . "'."); - $self->{output}->option_exit(); - } -} - -sub set { - my ($self, %options) = @_; - - $self->{output_template} = $options{output_template} if (defined($options{output_template})); - $self->{per_second} = $options{per_second} if (defined($options{per_second})); - $self->{instance} = $options{instance} if (defined($options{instance})); - $self->{key_values} = $options{key_values} if (defined($options{key_values})); - $self->{perfdata_extra_instance} = $options{perfdata_extra_instance} if (defined($options{perfdata_extra_instance})); - $self->{perfdata_template} = $options{perfdata_template} if (defined($options{perfdata_template})); - $self->{perfdata_use} = $options{perfdata_template} if (defined($options{perfdata_use})); - $self->{output_change_bytes} = $options{output_change_bytes} if (defined($options{output_change_bytes})); - $self->{absolute_unit} = $options{absolute_unit} if (defined($options{absolute_unit})); - $self->{per_second_unit} = $options{per_second_unit} if (defined($options{per_second_unit})); -} - -sub calc { - my ($self, %options) = @_; - - # manage only one value ;) - my $name = ${$self->{key_values}}[0]; - - if ($self->{per_second} == 1) { - $self->{result_values}->{per_second} = ($options{new_datas}->{$self->{instance} . '_' . $name} - $options{old_datas}->{$self->{instance} . '_' . $name}) / $options{delta_time} - } - $self->{result_values}->{absolute} = ($options{new_datas}->{$self->{instance} . '_' . $name} - $options{old_datas}->{$self->{instance} . '_' . $name}); - - return 1; -} - -sub check_threshold { - my ($self, %options) = @_; - my $value = $self->{result_values}->{absolute}; - - if ($self->{per_second} == 1) { - $value = $self->{result_values}->{per_second}; - } - return $self->{perfdata}->threshold_check(value => $value, threshold => [ { label => 'warning-' . $self->{label}, 'exit_litteral' => 'critical' }, - { label => 'critical-' . $self->{label}, 'exit_litteral' => 'warning' }]); -} - -sub output { - my ($self, %options) = @_; - my ($value, $unit) = ($self->{result_values}->{absolute}, $self->{result_values}->{absolute_unit}); - - if ($self->{per_second} == 1) { - $value = $self->{result_values}->{per_second}; - $unit = $self->{per_second_unit}; - } - if ($self->{output_change_bytes} == 1) { - ($value, $unit) = $self->{perfdata}->change_bytes(value => $value); - } - - return sprintf($self->{output_template}, $value, $unit); -} - -sub perfdata { - my ($self, %options) = @_; - my $extra_label = ''; - - $extra_label .= '_' . $self->{instance} if ($self->{perfdata_extra_instance} == 1); - $self->{output}->perfdata_add(label => $self->{label} . $extra_label, unit => $self->{perfdata_unit}, - value => sprintf($self->{perfdata_template}, $self->{result_values}->{$self->{perfdata_use}}), - warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}), - critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}), - min => 0); -} - -sub execute { - my ($self, %options) = @_; - my $old_datas = {}; - - my $quit = 0; - foreach my $value (@{$self->{key_values}}) { - $options{new_datas}->{$self->{instance} . '_' . $value} = $options{values}->{$value}; - $old_datas->{$self->{instance} . '_' . $value} = $self->{statefile}->get(name => $self->{instance} . '_' . $value); - if (!defined($old_datas->{$self->{instance} . '_' . $value})) { - $quit = 1; - next; - } - if ($old_datas->{$self->{instance} . '_' . $value} > $options{new_datas}->{$self->{instance} . '_' . $value}) { - $old_datas->{$self->{instance} . '_' . $value} = 0; - } - } - - return undef if ($quit == 1); - - if ($self->{per_second} == 1) { - if (!defined($self->{last_timestamp})) { - $self->{last_timestamp} = $self->{statefile}->get(name => 'last_timestamp'); - } - return undef if (!defined($self->{last_timestamp})); - } - - my $delta_time; - if ($self->{per_second} == 1) { - $delta_time = $options{new_datas}->{last_timestamp} - $self->{last_timestamp}; - if ($delta_time <= 0) { - $delta_time = 1; - } - } - - return $self->calc(old_datas => $old_datas, new_datas => $options{new_datas}, delta_time => $delta_time); -} - -1; - -__END__ - diff --git a/centreon/plugins/values.pm b/centreon/plugins/values.pm new file mode 100644 index 000000000..473689ced --- /dev/null +++ b/centreon/plugins/values.pm @@ -0,0 +1,235 @@ +################################################################################ +# Copyright 2005-2013 MERETHIS +# Centreon is developped by : Julien Mathis and Romain Le Merlus under +# GPL Licence 2.0. +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free Software +# Foundation ; either version 2 of the License. +# +# This program is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along with +# this program; if not, see . +# +# Linking this program statically or dynamically with other modules is making a +# combined work based on this program. Thus, the terms and conditions of the GNU +# General Public License cover the whole combination. +# +# As a special exception, the copyright holders of this program give MERETHIS +# permission to link this program with independent modules to produce an executable, +# regardless of the license terms of these independent modules, and to copy and +# distribute the resulting executable under terms of MERETHIS choice, provided that +# MERETHIS also meet, for each linked independent module, the terms and conditions +# of the license of that module. An independent module is a module which is not +# derived from this program. If you modify this program, you may extend this +# exception to your version of the program, but you are not obliged to do so. If you +# do not wish to do so, delete this exception statement from your version. +# +# For more information : contact@centreon.com +# Authors : Quentin Garnier +# +#################################################################################### + +package centreon::plugins::values; + +use strict; +use warnings; + +# le label de perfdata: on peut le surcharger (au lieu du label) +# le warning/critical: on peut surcharger + +sub new { + my ($class, %options) = @_; + my $self = {}; + bless $self, $class; + + $self->{statefile} = $options{statefile}; + $self->{output} = $options{output}; + $self->{perfdata} = $options{perfdata}; + $self->{label} = $options{label}; + + $self->{perfdatas} = []; + + $self->{output_template} = $self->{label} . ': %s'; + $self->{output_use} = undef; + $self->{output_change_bytes} = 0; + $self->{output_absolute_unit} = ''; + $self->{output_per_second_unit} = ''; + + $self->{threshold_use} = undef; + $self->{threshold_warn} = undef; + $self->{threshold_crit} = undef; + + $self->{per_second} = 0; + $self->{last_timestamp} = undef; + + $self->{result_values} = {}; + + return $self; +} + +sub init { + my ($self, %options) = @_; + my $warn = defined($self->{threshold_warn}) ? $self->{threshold_warn} : 'warning-' . $self->{label}; + my $crit = defined($self->{threshold_crit}) ? $self->{threshold_crit} : 'critical-' . $self->{label}; + + if (($self->{perfdata}->threshold_validate(label => $warn, value => $self->{option_results}->{$warn})) == 0) { + $self->{output}->add_option_msg(short_msg => "Wrong $warn threshold '" . $self->{option_results}->{$warn} . "'."); + $self->{output}->option_exit(); + } + if (($self->{perfdata}->threshold_validate(label => $crit, value => $self->{option_results}->{$crit})) == 0) { + $self->{output}->add_option_msg(short_msg => "Wrong $crit threshold '" . $self->{option_results}->{$crit} . "'."); + $self->{output}->option_exit(); + } +} + +sub set { + my ($self, %options) = @_; + + foreach (keys %options) { + $self->{$_} = $options{$_}; + } +} + +sub calc { + my ($self, %options) = @_; + + # manage only one value ;) + foreach my $value (@{$self->{key_values}}) { + if (defined($value->{diff}) && $value->{diff} == 1) { + if ($self->{per_second} == 1) { + $self->{result_values}->{$value->{name} . '_per_second'} = $options{new_datas}->{$self->{instance} . '_' . $value->{name}} - $options{old_datas}->{$self->{instance} . '_' . $value->{name}}) / $options{delta_time}; + } + $self->{result_values}->{$value->{name} . '_absolute'} = $options{new_datas}->{$self->{instance} . '_' . $value->{name}} - $options{old_datas}->{$self->{instance} . '_' . $value->{name}}), unit => $value->{unit}; + } else { + # absolute one. nothing to do + $self->{result_values}->{$value->{name} . '_absolute'} = $options{new_datas}->{$self->{instance} . '_' . . $value->{name}}; + } + } + + return 1; +} + +sub threshold_check { + my ($self, %options) = @_; + + if (defined($self->{closure_custom_threshpld})) { + return &{$self->{closure_custom_threshold}}($self); + } + + my $first = ${${$self->{key_values}}[0]}{name}; + my $value; + + if (!defined($self->{threshold_use})) { + $value = $self->{result_values}->{$first . '_absolute'}; + if ($self->{per_second} == 1) { + $value = $self->{result_values}->{$first . '_per_second'}; + } + } else { + $value = $self->{result_values}->{$self->{threshold_use}}; + } + + return $self->{perfdata}->threshold_check(value => $value, threshold => [ { label => 'warning-' . $self->{label}, 'exit_litteral' => 'critical' }, + { label => 'critical-' . $self->{label}, 'exit_litteral' => 'warning' }]); +} + +sub output { + my ($self, %options) = @_; + + if (defined($self->{closure_custom_output})) { + return &{$self->{closure_custom_output}}($self); + } + my $first = ${${$self->{key_values}}[0]}{name}; + my ($value, $unit) = ($self->{result_values}->{$first . '_absolute'}, $self->{result_values}->{output_absolute_unit}); + + if (!defined($self->{output_use})) { + if ($self->{per_second} == 1) { + $value = $self->{result_values}->{$first . '_per_second'}; + $unit = $self->{output_per_second_unit}; + } + } else { + $value = $self->{result_values}->{$self->{output_use}}; + } + + if ($self->{output_change_bytes} == 1) { + ($value, $unit) = $self->{perfdata}->change_bytes(value => $value); + } + + return sprintf($self->{output_template}, $value, $unit); +} + +sub perfdata { + my ($self, %options) = @_; + my $warn = defined($self->{threshold_warn}) ? $self->{threshold_warn} : 'warning-' . $self->{label}; + my $crit = defined($self->{threshold_crit}) ? $self->{threshold_crit} : 'critical-' . $self->{label}; + + foreach my $perf (@{$self->{perfdatas}}) { + my ($label, $extra_label) = ($self->{label}, ''); + my $template = '%s'; + + $template = $perf->{template} if (defined($perf->{template})); + $label = $perf->{label} if (defined($perf->{label})); + + $extra_label .= '_' . $self->{instance} if ($perf->{label_extra_instance} == 1 && !defined($options{no_extra_instance})); + $self->{output}->perfdata_add(label => $perf->{label} . $extra_label, unit => $perf->{unit}, + value => sprintf($template, $self->{result_values}->{$perf->{value}}), + warning => $self->{perfdata}->get_perfdata_for_output(label => $warn), + critical => $self->{perfdata}->get_perfdata_for_output(label => $crit), + min => $perf->{min}, max => $perf->{max}); + } +} + +sub execute { + my ($self, %options) = @_; + my $old_datas = {}; + + my $quit = 0; + my $per_second = 0; + + $options{new_datas} = {} if (!defined($options{new_datas})); + foreach my $value (@{$self->{key_values}}) { + if (defined($value->{diff}) && $value->{diff} == 1) { + $options{new_datas}->{$self->{instance} . '_' . $value} = $options{values}->{$value->{name}}; + $old_datas->{$self->{instance} . '_' . $value->{name}} = $self->{statefile}->get(name => $self->{instance} . '_' . $value->{name}); + if (!defined($old_datas->{$self->{instance} . '_' . $value->{name}})) { + $quit = 1; + next; + } + if ($old_datas->{$self->{instance} . '_' . $value->{name}} > $options{new_datas}->{$self->{instance} . '_' . $value->{name}}) { + $old_datas->{$self->{instance} . '_' . $value->{name}} = 0; + } + } else { + $options{new_datas}->{$self->{instance} . '_' . $value} = $options{values}->{$value->{name}}; + } + } + + return undef if ($quit == 1); + + if ($self->{per_second} == 1) { + if (!defined($self->{last_timestamp})) { + $self->{last_timestamp} = $self->{statefile}->get(name => 'last_timestamp'); + } + return undef if (!defined($self->{last_timestamp})); + } + + my $delta_time; + if ($self->{per_second} == 1) { + $delta_time = $options{new_datas}->{last_timestamp} - $self->{last_timestamp}; + if ($delta_time <= 0) { + $delta_time = 1; + } + } + + if (defined($self->{closure_custom_calc})) { + return &{$self->{closure_custom_cacl}}($self, old_datas => $old_datas, new_datas => $options{new_datas}, delta_time => $delta_time ); + } + return $self->calc(old_datas => $old_datas, new_datas => $options{new_datas}, delta_time => $delta_time); +} + +1; + +__END__ + diff --git a/storage/hp/p2000/xmlapi/mode/volumesstats.pm b/storage/hp/p2000/xmlapi/mode/volumesstats.pm index 91cb40958..8dfc40805 100644 --- a/storage/hp/p2000/xmlapi/mode/volumesstats.pm +++ b/storage/hp/p2000/xmlapi/mode/volumesstats.pm @@ -40,23 +40,47 @@ use base qw(centreon::plugins::mode); use strict; use warnings; use centreon::plugins::statefile; -use centreon::plugins::class::bytes; +use centreon::plugins::values; my $maps_counters = { - read => { class => 'centreon::plugins::class::bytes', obj => undef, + read => { class => 'centreon::plugins::values', obj => undef, set => { key_values => [ - 'data-read-numeric', + { name => 'data-read-numeric', diff => 1 }, ], - output_template => 'Read I/O : %s %s/s', per_second => 1, + per_second => 1, + output_template => 'Read I/O : %s %s/s', + output_change_bytes => 1, + perfdatas => [ + { value => 'data-read-numeric_absolute', + unit => 'B/s', min => 0, label_extra_instance => 1 }, + ], } }, - write => { class => 'centreon::plugins::class::bytes', obj => undef, - set => { - key_values => [ - 'data-written-numeric', + write => { class => 'centreon::plugins::values', obj => undef, + set => { + key_values => [ + { name => 'data-written-numeric', diff => 1 }, ], - output_template => 'Write I/O : %s %s/s', per_second => 1, + per_second => 1, + output_template => 'Write I/O : %s %s/s', + output_change_bytes => 1, + perfdatas => [ + { value => 'data-written-numeric_absolute', + unit => 'B/s', min => 0, label_extra_instance => 1 }, + ], + } + }, + iops => { class => 'centreon::plugins::values', obj => undef, + set => { + key_values => [ + { name => 'iops' }, + ], + output_template => 'IOPs : %s', + perfdatas => [ + { value => 'iops_absolute', + unit => 'iops', min => 0, label_extra_instance => 1 }, + ], } }, }; @@ -164,7 +188,7 @@ sub run { new_datas => $self->{new_datas}); next if (!defined($value_check)); - my $exit2 = $maps_counters->{$_}->{obj}->check_threshold(); + my $exit2 = $maps_counters->{$_}->{obj}->threshold_check(); push @exits, $exit2; my $output = $maps_counters->{$_}->{obj}->output();