move prometheus kubernetes to new perfdata

This commit is contained in:
Colin Gagnaire 2019-06-07 12:01:55 +02:00
parent e05005b96d
commit f8146e1e2a
5 changed files with 228 additions and 188 deletions

View File

@ -68,7 +68,7 @@ sub set_counters {
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold,
} }
}, },
{ label => 'restarts-count', set => { { label => 'restarts-count', nlabel => 'kubernetes.container.restarts.count', set => {
key_values => [ { name => 'restarts' }, { name => 'perf' } ], key_values => [ { name => 'restarts' }, { name => 'perf' } ],
output_template => 'Restarts count : %d', output_template => 'Restarts count : %d',
perfdatas => [ perfdatas => [
@ -92,16 +92,15 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ "container:s" => { name => 'container', default => 'container=~".*"' },
"container:s" => { name => 'container', default => 'container=~".*"' }, "pod:s" => { name => 'pod', default => 'pod=~".*"' },
"pod:s" => { name => 'pod', default => 'pod=~".*"' }, "warning-status:s" => { name => 'warning_status', default => '' },
"warning-status:s" => { name => 'warning_status', default => '' }, "critical-status:s" => { name => 'critical_status', default => '%{status} !~ /running/ || %{state} !~ /ready/' },
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /running/ || %{state} !~ /ready/' }, "extra-filter:s@" => { name => 'extra_filter' },
"extra-filter:s@" => { name => 'extra_filter' }, "metric-overload:s@" => { name => 'metric_overload' },
"metric-overload:s@" => { name => 'metric_overload' }, "filter-counters:s" => { name => 'filter_counters' },
"filter-counters:s" => { name => 'filter_counters' }, });
});
return $self; return $self;
} }
@ -146,34 +145,38 @@ sub manage_selection {
$self->{containers} = {}; $self->{containers} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{ready} . '",' . my $results = $options{custom}->query(
$self->{option_results}->{container} . ',' . queries => [
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{ready} . '",' .
$self->{extra_filter} . '}, "__name__", "ready", "", "")', $self->{option_results}->{container} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{running} . '",' . $self->{option_results}->{pod} .
$self->{option_results}->{container} . ',' . $self->{extra_filter} . '}, "__name__", "ready", "", "")',
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{running} . '",' .
$self->{extra_filter} . '}, "__name__", "running", "", "")', $self->{option_results}->{container} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{terminated} . '",' . $self->{option_results}->{pod} .
$self->{option_results}->{container} . ',' . $self->{extra_filter} . '}, "__name__", "running", "", "")',
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{terminated} . '",' .
$self->{extra_filter} . '}, "__name__", "terminated", "", "")', $self->{option_results}->{container} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{terminated_reason} . '",' . $self->{option_results}->{pod} .
$self->{option_results}->{container} . ',' . $self->{extra_filter} . '}, "__name__", "terminated", "", "")',
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{terminated_reason} . '",' .
$self->{extra_filter} . '}, "__name__", "terminated_reason", "", "")', $self->{option_results}->{container} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{waiting} . '",' . $self->{option_results}->{pod} .
$self->{option_results}->{container} . ',' . $self->{extra_filter} . '}, "__name__", "terminated_reason", "", "")',
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{waiting} . '",' .
$self->{extra_filter} . '}, "__name__", "waiting", "", "")', $self->{option_results}->{container} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{waiting_reason} . '",' . $self->{option_results}->{pod} .
$self->{option_results}->{container} . ',' . $self->{extra_filter} . '}, "__name__", "waiting", "", "")',
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{waiting_reason} . '",' .
$self->{extra_filter} . '}, "__name__", "waiting_reason", "", "")', $self->{option_results}->{container} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{restarts} . '",' . $self->{option_results}->{pod} .
$self->{option_results}->{container} . ',' . $self->{extra_filter} . '}, "__name__", "waiting_reason", "", "")',
$self->{option_results}->{pod} . 'label_replace({__name__=~"' . $self->{metrics}->{restarts} . '",' .
$self->{extra_filter} . '}, "__name__", "restarts", "", "")' ]); $self->{option_results}->{container} . ',' .
$self->{option_results}->{pod} .
$self->{extra_filter} . '}, "__name__", "restarts", "", "")'
]
);
foreach my $result (@{$results}) { foreach my $result (@{$results}) {
next if (!defined($result->{metric}->{$self->{labels}->{pod}}) || !defined($result->{metric}->{$self->{labels}->{container}})); next if (!defined($result->{metric}->{$self->{labels}->{pod}}) || !defined($result->{metric}->{$self->{labels}->{container}}));

View File

@ -29,25 +29,48 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
sub custom_status_perfdata { sub custom_status_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
my $extra_label = ''; $self->{output}->perfdata_add(
if (!defined($options{extra_instance}) || $options{extra_instance} != 0) { label => 'desired',
$extra_label .= '_' . $self->{result_values}->{display}; nlabel => 'kubernetes.daemonset.nodes.desired.count',
} value => $self->{result_values}->{desired},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
$self->{output}->perfdata_add(label => 'desired' . $extra_label, );
value => $self->{result_values}->{desired}); $self->{output}->perfdata_add(
$self->{output}->perfdata_add(label => 'current' . $extra_label, label => 'current',
value => $self->{result_values}->{current}); nlabel => 'kubernetes.daemonset.nodes.current.count',
$self->{output}->perfdata_add(label => 'available' . $extra_label, value => $self->{result_values}->{current},
value => $self->{result_values}->{available}); instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
$self->{output}->perfdata_add(label => 'unavailable' . $extra_label, );
value => $self->{result_values}->{unavailable}); $self->{output}->perfdata_add(
$self->{output}->perfdata_add(label => 'up_to_date' . $extra_label, label => 'available',
value => $self->{result_values}->{up_to_date}); nlabel => 'kubernetes.daemonset.nodes.available.count',
$self->{output}->perfdata_add(label => 'ready' . $extra_label, value => $self->{result_values}->{available},
value => $self->{result_values}->{ready}); instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
$self->{output}->perfdata_add(label => 'misscheduled' . $extra_label, );
value => $self->{result_values}->{misscheduled}); $self->{output}->perfdata_add(
label => 'unavailable',
nlabel => 'kubernetes.daemonset.nodes.unavailable.count',
value => $self->{result_values}->{unavailable},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'up_to_date',
nlabel => 'kubernetes.daemonset.nodes.uptodate.count',
value => $self->{result_values}->{up_to_date},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'ready',
nlabel => 'kubernetes.daemonset.nodes.ready.count',
value => $self->{result_values}->{ready},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'misscheduled',
nlabel => 'kubernetes.daemonset.nodes.misscheduled.count',
value => $self->{result_values}->{misscheduled},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
} }
sub custom_status_output { sub custom_status_output {
@ -112,14 +135,13 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ "daemonset:s" => { name => 'daemonset', default => 'daemonset=~".*"' },
"daemonset:s" => { name => 'daemonset', default => 'daemonset=~".*"' }, "warning-status:s" => { name => 'warning_status', default => '%{up_to_date} < %{desired}' },
"warning-status:s" => { name => 'warning_status', default => '%{up_to_date} < %{desired}' }, "critical-status:s" => { name => 'critical_status', default => '%{available} < %{desired}' },
"critical-status:s" => { name => 'critical_status', default => '%{available} < %{desired}' }, "extra-filter:s@" => { name => 'extra_filter' },
"extra-filter:s@" => { name => 'extra_filter' }, "metric-overload:s@" => { name => 'metric_overload' },
"metric-overload:s@" => { name => 'metric_overload' }, });
});
return $self; return $self;
} }
@ -164,27 +186,31 @@ sub manage_selection {
$self->{daemonsets} = {}; $self->{daemonsets} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' . my $results = $options{custom}->query(
$self->{option_results}->{daemonset} . queries => [
$self->{extra_filter} . '}, "__name__", "desired", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{current} . '",' . $self->{option_results}->{daemonset} .
$self->{option_results}->{daemonset} . $self->{extra_filter} . '}, "__name__", "desired", "", "")',
$self->{extra_filter} . '}, "__name__", "current", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{current} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{available} . '",' . $self->{option_results}->{daemonset} .
$self->{option_results}->{daemonset} . $self->{extra_filter} . '}, "__name__", "current", "", "")',
$self->{extra_filter} . '}, "__name__", "available", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{available} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{unavailable} . '",' . $self->{option_results}->{daemonset} .
$self->{option_results}->{daemonset} . $self->{extra_filter} . '}, "__name__", "available", "", "")',
$self->{extra_filter} . '}, "__name__", "unavailable", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{unavailable} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{up_to_date} . '",' . $self->{option_results}->{daemonset} .
$self->{option_results}->{daemonset} . $self->{extra_filter} . '}, "__name__", "unavailable", "", "")',
$self->{extra_filter} . '}, "__name__", "up_to_date", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{up_to_date} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{ready} . '",' . $self->{option_results}->{daemonset} .
$self->{option_results}->{daemonset} . $self->{extra_filter} . '}, "__name__", "up_to_date", "", "")',
$self->{extra_filter} . '}, "__name__", "ready", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{ready} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{misscheduled} . '",' . $self->{option_results}->{daemonset} .
$self->{option_results}->{daemonset} . $self->{extra_filter} . '}, "__name__", "ready", "", "")',
$self->{extra_filter} . '}, "__name__", "misscheduled", "", "")' ]); 'label_replace({__name__=~"' . $self->{metrics}->{misscheduled} . '",' .
$self->{option_results}->{daemonset} .
$self->{extra_filter} . '}, "__name__", "misscheduled", "", "")'
]
);
foreach my $result (@{$results}) { foreach my $result (@{$results}) {
$self->{daemonsets}->{$result->{metric}->{$self->{labels}->{daemonset}}}->{display} = $result->{metric}->{$self->{labels}->{daemonset}}; $self->{daemonsets}->{$result->{metric}->{$self->{labels}->{daemonset}}}->{display} = $result->{metric}->{$self->{labels}->{daemonset}};

View File

@ -29,21 +29,36 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
sub custom_status_perfdata { sub custom_status_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
my $extra_label = ''; $self->{output}->perfdata_add(
if (!defined($options{extra_instance}) || $options{extra_instance} != 0) { label => 'desired',
$extra_label .= '_' . $self->{result_values}->{display}; nlabel => 'kubernetes.deployment.replicas.desired.count',
} value => $self->{result_values}->{desired},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
$self->{output}->perfdata_add(label => 'desired' . $extra_label, );
value => $self->{result_values}->{desired}); $self->{output}->perfdata_add(
$self->{output}->perfdata_add(label => 'current' . $extra_label, label => 'current',
value => $self->{result_values}->{current}); nlabel => 'kubernetes.deployment.replicas.current.count',
$self->{output}->perfdata_add(label => 'available' . $extra_label, value => $self->{result_values}->{current},
value => $self->{result_values}->{available}); instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
$self->{output}->perfdata_add(label => 'unavailable' . $extra_label, );
value => $self->{result_values}->{unavailable}); $self->{output}->perfdata_add(
$self->{output}->perfdata_add(label => 'up_to_date' . $extra_label, label => 'available',
value => $self->{result_values}->{up_to_date}); nlabel => 'kubernetes.deployment.replicas.available.count',
value => $self->{result_values}->{available},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'unavailable',
nlabel => 'kubernetes.deployment.replicas.unavailable.count',
value => $self->{result_values}->{unavailable},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'up_to_date',
nlabel => 'kubernetes.deployment.replicas.uptodate.count',
value => $self->{result_values}->{up_to_date},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
} }
sub custom_status_output { sub custom_status_output {
@ -103,14 +118,13 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ "deployment:s" => { name => 'deployment', default => 'deployment=~".*"' },
"deployment:s" => { name => 'deployment', default => 'deployment=~".*"' }, "warning-status:s" => { name => 'warning_status', default => '%{up_to_date} < %{desired}' },
"warning-status:s" => { name => 'warning_status', default => '%{up_to_date} < %{desired}' }, "critical-status:s" => { name => 'critical_status', default => '%{available} < %{desired}' },
"critical-status:s" => { name => 'critical_status', default => '%{available} < %{desired}' }, "extra-filter:s@" => { name => 'extra_filter' },
"extra-filter:s@" => { name => 'extra_filter' }, "metric-overload:s@" => { name => 'metric_overload' },
"metric-overload:s@" => { name => 'metric_overload' }, });
});
return $self; return $self;
} }
@ -153,21 +167,25 @@ sub manage_selection {
$self->{deployments} = {}; $self->{deployments} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' . my $results = $options{custom}->query(
$self->{option_results}->{deployment} . queries => [
$self->{extra_filter} . '}, "__name__", "desired", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{current} . '",' . $self->{option_results}->{deployment} .
$self->{option_results}->{deployment} . $self->{extra_filter} . '}, "__name__", "desired", "", "")',
$self->{extra_filter} . '}, "__name__", "current", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{current} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{available} . '",' . $self->{option_results}->{deployment} .
$self->{option_results}->{deployment} . $self->{extra_filter} . '}, "__name__", "current", "", "")',
$self->{extra_filter} . '}, "__name__", "available", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{available} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{unavailable} . '",' . $self->{option_results}->{deployment} .
$self->{option_results}->{deployment} . $self->{extra_filter} . '}, "__name__", "available", "", "")',
$self->{extra_filter} . '}, "__name__", "unavailable", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{unavailable} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{up_to_date} . '",' . $self->{option_results}->{deployment} .
$self->{option_results}->{deployment} . $self->{extra_filter} . '}, "__name__", "unavailable", "", "")',
$self->{extra_filter} . '}, "__name__", "up_to_date", "", "")' ]); 'label_replace({__name__=~"' . $self->{metrics}->{up_to_date} . '",' .
$self->{option_results}->{deployment} .
$self->{extra_filter} . '}, "__name__", "up_to_date", "", "")'
]
);
foreach my $result (@{$results}) { foreach my $result (@{$results}) {
$self->{deployments}->{$result->{metric}->{$self->{labels}->{deployment}}}->{display} = $result->{metric}->{$self->{labels}->{deployment}}; $self->{deployments}->{$result->{metric}->{$self->{labels}->{deployment}}}->{display} = $result->{metric}->{$self->{labels}->{deployment}};

View File

@ -46,11 +46,12 @@ sub set_counters {
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'global', type => 0, cb_init => 'skip_global', cb_prefix_output => 'prefix_global_output' }, { name => 'global', type => 0, cb_init => 'skip_global', cb_prefix_output => 'prefix_global_output' },
{ name => 'namespaces', type => 1, cb_prefix_output => 'prefix_namespace_output', message_multiple => 'All namespaces status are ok', skipped_code => { -11 => 1 } }, { name => 'namespaces', type => 1, cb_prefix_output => 'prefix_namespace_output',
message_multiple => 'All namespaces status are ok', skipped_code => { -11 => 1 } },
]; ];
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
{ label => 'active', set => { { label => 'active', nlabel => 'kubernetes.namespace.active.count', set => {
key_values => [ { name => 'active' } ], key_values => [ { name => 'active' } ],
output_template => 'Active : %d', output_template => 'Active : %d',
perfdatas => [ perfdatas => [
@ -59,7 +60,7 @@ sub set_counters {
], ],
} }
}, },
{ label => 'terminating', set => { { label => 'terminating', nlabel => 'kubernetes.namespace.terminating.count', set => {
key_values => [ { name => 'terminating' } ], key_values => [ { name => 'terminating' } ],
output_template => 'Terminating : %d', output_template => 'Terminating : %d',
perfdatas => [ perfdatas => [
@ -105,15 +106,14 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ "namespace:s" => { name => 'namespace', default => 'namespace=~".*"' },
"namespace:s" => { name => 'namespace', default => 'namespace=~".*"' }, "phase:s" => { name => 'phase', default => 'phase=~".*"' },
"phase:s" => { name => 'phase', default => 'phase=~".*"' }, "warning-status:s" => { name => 'warning_status' },
"warning-status:s" => { name => 'warning_status' }, "critical-status:s" => { name => 'critical_status', default => '%{phase} !~ /Active/' },
"critical-status:s" => { name => 'critical_status', default => '%{phase} !~ /Active/' }, "extra-filter:s@" => { name => 'extra_filter' },
"extra-filter:s@" => { name => 'extra_filter' }, "metric-overload:s@" => { name => 'metric_overload' },
"metric-overload:s@" => { name => 'metric_overload' }, });
});
return $self; return $self;
} }
@ -153,9 +153,13 @@ sub manage_selection {
$self->{global} = { active => 0, terminating => 0 }; $self->{global} = { active => 0, terminating => 0 };
$self->{namespaces} = {}; $self->{namespaces} = {};
my $results = $options{custom}->query(queries => [ '{__name__=~"' . $self->{metrics}->{status} . '",' . my $results = $options{custom}->query(
$self->{option_results}->{namespace} . queries => [
$self->{extra_filter} . '}' ]); '{__name__=~"' . $self->{metrics}->{status} . '",' .
$self->{option_results}->{namespace} .
$self->{extra_filter} . '}'
]
);
foreach my $result (@{$results}) { foreach my $result (@{$results}) {
$self->{namespaces}->{$result->{metric}->{$self->{labels}->{namespace}}}->{display} = $result->{metric}->{$self->{labels}->{namespace}}; $self->{namespaces}->{$result->{metric}->{$self->{labels}->{namespace}}}->{display} = $result->{metric}->{$self->{labels}->{namespace}};

View File

@ -49,8 +49,7 @@ sub custom_usage_perfdata {
my $label = 'allocated_pods'; my $label = 'allocated_pods';
my $value_perf = $self->{result_values}->{allocated}; my $value_perf = $self->{result_values}->{allocated};
my $extra_label = '';
$extra_label = '_' . $self->{result_values}->{display} if (!defined($options{extra_instance}) || $options{extra_instance} != 0);
my %total_options = (); my %total_options = ();
if ($self->{instance_mode}->{option_results}->{units} eq '%') { if ($self->{instance_mode}->{option_results}->{units} eq '%') {
$total_options{total} = $self->{result_values}->{allocatable}; $total_options{total} = $self->{result_values}->{allocatable};
@ -58,11 +57,13 @@ sub custom_usage_perfdata {
} }
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => $label . $extra_label, label => $label,
nlabel => 'kubernetes.pods.allocated.count',
value => $value_perf, value => $value_perf,
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, %total_options), warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}, %total_options),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, %total_options), critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}, %total_options),
min => 0, max => $self->{result_values}->{allocatable} min => 0, max => $self->{result_values}->{allocatable},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
); );
} }
@ -75,23 +76,8 @@ sub custom_usage_threshold {
$threshold_value = $self->{result_values}->{prct_allocated}; $threshold_value = $self->{result_values}->{prct_allocated};
} }
$exit = $self->{perfdata}->threshold_check( $exit = $self->{perfdata}->threshold_check(
value => $threshold_value, threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, value => $threshold_value, threshold => [ { label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
{ label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ] { label => 'warning-'. $self->{thlabel}, exit_litteral => 'warning' } ]
);
return $exit;
}
sub custom_usage_threshold {
my ($self, %options) = @_;
my ($exit, $threshold_value);
$threshold_value = $self->{result_values}->{allocated};
if ($self->{instance_mode}->{option_results}->{units} eq '%') {
$threshold_value = $self->{result_values}->{prct_allocated};
}
$exit = $self->{perfdata}->threshold_check(
value => $threshold_value, threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' },
{ label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]
); );
return $exit; return $exit;
} }
@ -160,15 +146,14 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ "node:s" => { name => 'node', default => 'node=~".*"' },
"node:s" => { name => 'node', default => 'node=~".*"' }, "warning-status:s" => { name => 'warning_status' },
"warning-status:s" => { name => 'warning_status' }, "critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Ready/ || %{schedulable} =~ /false/' },
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Ready/ || %{schedulable} =~ /false/' }, "extra-filter:s@" => { name => 'extra_filter' },
"extra-filter:s@" => { name => 'extra_filter' }, "metric-overload:s@" => { name => 'metric_overload' },
"metric-overload:s@" => { name => 'metric_overload' }, "units:s" => { name => 'units', default => '' },
"units:s" => { name => 'units', default => '' }, });
});
return $self; return $self;
} }
@ -211,22 +196,26 @@ sub manage_selection {
$self->{nodes} = {}; $self->{nodes} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{status} . '",' . my $results = $options{custom}->query(
$self->{option_results}->{node} . ',' . queries => [
'status="true"' . 'label_replace({__name__=~"' . $self->{metrics}->{status} . '",' .
$self->{extra_filter} . '}, "__name__", "status", "", "")', $self->{option_results}->{node} . ',' .
'label_replace({__name__=~"' . $self->{metrics}->{unschedulable} . '",' . 'status="true"' .
$self->{option_results}->{node} . $self->{extra_filter} . '}, "__name__", "status", "", "")',
$self->{extra_filter} . '}, "__name__", "unschedulable", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{unschedulable} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{capacity} . '",' . $self->{option_results}->{node} .
$self->{option_results}->{node} . $self->{extra_filter} . '}, "__name__", "unschedulable", "", "")',
$self->{extra_filter} . '}, "__name__", "capacity", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{capacity} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{allocatable} . '",' . $self->{option_results}->{node} .
$self->{option_results}->{node} . $self->{extra_filter} . '}, "__name__", "capacity", "", "")',
$self->{extra_filter} . '}, "__name__", "allocatable", "", "")', 'label_replace({__name__=~"' . $self->{metrics}->{allocatable} . '",' .
'label_replace({__name__=~"' . $self->{metrics}->{allocated} . '",' . $self->{option_results}->{node} .
$self->{option_results}->{node} . $self->{extra_filter} . '}, "__name__", "allocatable", "", "")',
$self->{extra_filter} . '}, "__name__", "allocated", "", "")' ]); 'label_replace({__name__=~"' . $self->{metrics}->{allocated} . '",' .
$self->{option_results}->{node} .
$self->{extra_filter} . '}, "__name__", "allocated", "", "")'
]
);
foreach my $result (@{$results}) { foreach my $result (@{$results}) {
$self->{nodes}->{$result->{metric}->{$self->{labels}->{node}}}->{display} = $result->{metric}->{$self->{labels}->{node}}; $self->{nodes}->{$result->{metric}->{$self->{labels}->{node}}}->{display} = $result->{metric}->{$self->{labels}->{node}};