move prometheus kubernetes to new perfdata
This commit is contained in:
parent
e05005b96d
commit
f8146e1e2a
|
@ -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}}));
|
||||||
|
|
|
@ -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}};
|
||||||
|
|
|
@ -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}};
|
||||||
|
|
|
@ -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}};
|
||||||
|
|
|
@ -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}};
|
||||||
|
|
Loading…
Reference in New Issue