WIP: new perfdata system
This commit is contained in:
parent
1f153d5ff1
commit
aa4608e30d
|
@ -43,7 +43,7 @@ sub custom_status_calc {
|
|||
sub custom_usage_perfdata {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my ($label, $nlabel) = ('used', $self->{label});
|
||||
my ($label, $nlabel) = ('used', $self->{nlabel});
|
||||
my $value_perf = $self->{result_values}->{used};
|
||||
if (defined($self->{instance_mode}->{option_results}->{free})) {
|
||||
($label, $nlabel) = ('free', 'datastore.space.free.bytes');
|
||||
|
|
|
@ -43,7 +43,7 @@ sub custom_status_calc {
|
|||
sub custom_usage_perfdata {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my ($label, $nlabel) = ('used', $self->{label});
|
||||
my ($label, $nlabel) = ('used', $self->{nlabel});
|
||||
my $value_perf = $self->{result_values}->{used};
|
||||
if (defined($self->{instance_mode}->{option_results}->{free})) {
|
||||
($label, $nlabel) = ('free', 'host.memory.free.bytes');
|
||||
|
|
|
@ -44,7 +44,7 @@ sub custom_status_calc {
|
|||
sub custom_usage_perfdata {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my ($label, $nlabel) = ('used', $self->{label});
|
||||
my ($label, $nlabel) = ('used', $self->{nlabel});
|
||||
my $value_perf = $self->{result_values}->{used};
|
||||
if (defined($self->{instance_mode}->{option_results}->{free})) {
|
||||
($label, $nlabel) = ('free', 'vm.memory.free.bytes');
|
||||
|
|
|
@ -28,7 +28,7 @@ use warnings;
|
|||
sub custom_usage_perfdata {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my ($label, $nlabel, $unit, $total) = ('used', $self->{label}, '%', 100);
|
||||
my ($label, $nlabel, $unit, $total) = ('used', $self->{nlabel}, '%', 100);
|
||||
my $value_perf = $self->{result_values}->{prct_used};
|
||||
my %total_options = ();
|
||||
if ($self->{result_values}->{total} != -1) {
|
||||
|
|
|
@ -146,9 +146,11 @@ sub new {
|
|||
});
|
||||
}
|
||||
}
|
||||
$_->{obj} = centreon::plugins::values->new(statefile => $self->{statefile_value},
|
||||
output => $self->{output}, perfdata => $self->{perfdata},
|
||||
label => $label, thlabel => $thlabel);
|
||||
$_->{obj} = centreon::plugins::values->new(
|
||||
statefile => $self->{statefile_value},
|
||||
output => $self->{output}, perfdata => $self->{perfdata},
|
||||
label => $_->{label}, nlabel => $_->{nlabel}, thlabel => $thlabel,
|
||||
);
|
||||
$_->{obj}->set(%{$_->{set}});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -35,6 +35,7 @@ sub new {
|
|||
$self->{output} = $options{output};
|
||||
$self->{perfdata} = $options{perfdata};
|
||||
$self->{label} = $options{label};
|
||||
$self->{nlabel} = $options{nlabel};
|
||||
$self->{thlabel} = defined($options{thlabel}) ? $options{thlabel} : $self->{label};
|
||||
|
||||
$self->{perfdatas} = [];
|
||||
|
@ -211,16 +212,11 @@ sub perfdata {
|
|||
$instances = $instance;
|
||||
}
|
||||
}
|
||||
|
||||
my %nlabel_option = ();
|
||||
if ($self->{output}->use_new_perfdata()) {
|
||||
$nlabel_option{nlabel} = $self->{label};
|
||||
}
|
||||
|
||||
$self->{output}->perfdata_add(
|
||||
label => $label,
|
||||
instances => $instances,
|
||||
%nlabel_option,
|
||||
nlabel => $self->{nlabel},
|
||||
unit => $perf->{unit},
|
||||
value => $cast_int == 1 ? int($self->{result_values}->{$perf->{value}}) : sprintf($template, $self->{result_values}->{$perf->{value}}),
|
||||
warning => $self->{perfdata}->get_perfdata_for_output(label => $warn, total => $th_total, cast_int => $cast_int),
|
||||
|
|
|
@ -78,12 +78,14 @@ sub check {
|
|||
$self->{output}->output_add(severity => $exit,
|
||||
short_msg => sprintf("Cpu '%s' temperature is %s celsius degrees", $result->{bladeCPUMark}, $result->{bladeCPUTemperature}));
|
||||
}
|
||||
$self->{output}->perfdata_add(label => 'temperature_' . $result->{bladeCPUMark}, unit => 'C',
|
||||
value => $result->{bladeCPUTemperature},
|
||||
warning => $warn,
|
||||
critical => $crit,
|
||||
min => 0
|
||||
);
|
||||
$self->{output}->perfdata_add(
|
||||
label => 'temperature', unit => 'C',
|
||||
nlabel => 'hardware.cpu.temperature.celsius',
|
||||
instances => $result->{bladeCPUMark},
|
||||
value => $result->{bladeCPUTemperature},
|
||||
warning => $warn,
|
||||
critical => $crit, min => 0
|
||||
);
|
||||
}
|
||||
|
||||
$self->{output}->output_add(long_msg => sprintf("Cpu '%s' status is '%s' [instance = %s]",
|
||||
|
@ -98,4 +100,4 @@ sub check {
|
|||
}
|
||||
}
|
||||
|
||||
1;
|
||||
1;
|
||||
|
|
|
@ -64,12 +64,15 @@ sub check {
|
|||
short_msg => sprintf("Temperature '%s' is '%s' celsius degrees", $result->{bladeTemperatureIndex}, $result->{bladeTemperatureReading}));
|
||||
}
|
||||
|
||||
$self->{output}->perfdata_add(label => 'temperature_' . $result->{bladeTemperatureIndex}, unit => 'C',
|
||||
value => $result->{bladeTemperatureReading},
|
||||
warning => $warn,
|
||||
critical => $crit
|
||||
);
|
||||
$self->{output}->perfdata_add(
|
||||
label => 'temperature', unit => 'C',
|
||||
nlabel => 'hardware.temperature.celsius',
|
||||
instances => $result->{bladeTemperatureIndex},
|
||||
value => $result->{bladeTemperatureReading},
|
||||
warning => $warn,
|
||||
critical => $crit
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
1;
|
||||
1;
|
||||
|
|
|
@ -72,7 +72,7 @@ my %storage_types_manage = (
|
|||
sub custom_usage_perfdata {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my ($label, $nlabel) = ('used', $self->{label});
|
||||
my ($label, $nlabel) = ('used', $self->{nlabel});
|
||||
my $value_perf = $self->{result_values}->{used};
|
||||
if (defined($self->{instance_mode}->{option_results}->{free})) {
|
||||
($label, $nlabel) = ('free', 'storage.space.free.bytes');
|
||||
|
|
|
@ -28,7 +28,7 @@ use warnings;
|
|||
sub custom_usage_perfdata {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my ($label, $nlabel) = ('used', $self->{label});
|
||||
my ($label, $nlabel) = ('used', $self->{nlabel});
|
||||
my $value_perf = $self->{result_values}->{used};
|
||||
if (defined($self->{instance_mode}->{option_results}->{free})) {
|
||||
($label, $nlabel) = ('free', 'memory.free.bytes');
|
||||
|
|
Loading…
Reference in New Issue