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,
}
},
{ label => 'restarts-count', set => {
{ label => 'restarts-count', nlabel => 'kubernetes.container.restarts.count', set => {
key_values => [ { name => 'restarts' }, { name => 'perf' } ],
output_template => 'Restarts count : %d',
perfdatas => [
@ -92,8 +92,7 @@ sub new {
bless $self, $class;
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
$options{options}->add_options(arguments => {
"container:s" => { name => 'container', default => 'container=~".*"' },
"pod:s" => { name => 'pod', default => 'pod=~".*"' },
"warning-status:s" => { name => 'warning_status', default => '' },
@ -146,7 +145,9 @@ sub manage_selection {
$self->{containers} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{ready} . '",' .
my $results = $options{custom}->query(
queries => [
'label_replace({__name__=~"' . $self->{metrics}->{ready} . '",' .
$self->{option_results}->{container} . ',' .
$self->{option_results}->{pod} .
$self->{extra_filter} . '}, "__name__", "ready", "", "")',
@ -173,7 +174,9 @@ sub manage_selection {
'label_replace({__name__=~"' . $self->{metrics}->{restarts} . '",' .
$self->{option_results}->{container} . ',' .
$self->{option_results}->{pod} .
$self->{extra_filter} . '}, "__name__", "restarts", "", "")' ]);
$self->{extra_filter} . '}, "__name__", "restarts", "", "")'
]
);
foreach my $result (@{$results}) {
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 {
my ($self, %options) = @_;
my $extra_label = '';
if (!defined($options{extra_instance}) || $options{extra_instance} != 0) {
$extra_label .= '_' . $self->{result_values}->{display};
}
$self->{output}->perfdata_add(label => 'desired' . $extra_label,
value => $self->{result_values}->{desired});
$self->{output}->perfdata_add(label => 'current' . $extra_label,
value => $self->{result_values}->{current});
$self->{output}->perfdata_add(label => 'available' . $extra_label,
value => $self->{result_values}->{available});
$self->{output}->perfdata_add(label => 'unavailable' . $extra_label,
value => $self->{result_values}->{unavailable});
$self->{output}->perfdata_add(label => 'up_to_date' . $extra_label,
value => $self->{result_values}->{up_to_date});
$self->{output}->perfdata_add(label => 'ready' . $extra_label,
value => $self->{result_values}->{ready});
$self->{output}->perfdata_add(label => 'misscheduled' . $extra_label,
value => $self->{result_values}->{misscheduled});
$self->{output}->perfdata_add(
label => 'desired',
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 => 'current',
nlabel => 'kubernetes.daemonset.nodes.current.count',
value => $self->{result_values}->{current},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'available',
nlabel => 'kubernetes.daemonset.nodes.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.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 {
@ -112,8 +135,7 @@ sub new {
bless $self, $class;
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
$options{options}->add_options(arguments => {
"daemonset:s" => { name => 'daemonset', default => 'daemonset=~".*"' },
"warning-status:s" => { name => 'warning_status', default => '%{up_to_date} < %{desired}' },
"critical-status:s" => { name => 'critical_status', default => '%{available} < %{desired}' },
@ -164,7 +186,9 @@ sub manage_selection {
$self->{daemonsets} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' .
my $results = $options{custom}->query(
queries => [
'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' .
$self->{option_results}->{daemonset} .
$self->{extra_filter} . '}, "__name__", "desired", "", "")',
'label_replace({__name__=~"' . $self->{metrics}->{current} . '",' .
@ -184,7 +208,9 @@ sub manage_selection {
$self->{extra_filter} . '}, "__name__", "ready", "", "")',
'label_replace({__name__=~"' . $self->{metrics}->{misscheduled} . '",' .
$self->{option_results}->{daemonset} .
$self->{extra_filter} . '}, "__name__", "misscheduled", "", "")' ]);
$self->{extra_filter} . '}, "__name__", "misscheduled", "", "")'
]
);
foreach my $result (@{$results}) {
$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 {
my ($self, %options) = @_;
my $extra_label = '';
if (!defined($options{extra_instance}) || $options{extra_instance} != 0) {
$extra_label .= '_' . $self->{result_values}->{display};
}
$self->{output}->perfdata_add(label => 'desired' . $extra_label,
value => $self->{result_values}->{desired});
$self->{output}->perfdata_add(label => 'current' . $extra_label,
value => $self->{result_values}->{current});
$self->{output}->perfdata_add(label => 'available' . $extra_label,
value => $self->{result_values}->{available});
$self->{output}->perfdata_add(label => 'unavailable' . $extra_label,
value => $self->{result_values}->{unavailable});
$self->{output}->perfdata_add(label => 'up_to_date' . $extra_label,
value => $self->{result_values}->{up_to_date});
$self->{output}->perfdata_add(
label => 'desired',
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 => 'current',
nlabel => 'kubernetes.deployment.replicas.current.count',
value => $self->{result_values}->{current},
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{display} : undef,
);
$self->{output}->perfdata_add(
label => 'available',
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 {
@ -103,8 +118,7 @@ sub new {
bless $self, $class;
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
$options{options}->add_options(arguments => {
"deployment:s" => { name => 'deployment', default => 'deployment=~".*"' },
"warning-status:s" => { name => 'warning_status', default => '%{up_to_date} < %{desired}' },
"critical-status:s" => { name => 'critical_status', default => '%{available} < %{desired}' },
@ -153,7 +167,9 @@ sub manage_selection {
$self->{deployments} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' .
my $results = $options{custom}->query(
queries => [
'label_replace({__name__=~"' . $self->{metrics}->{desired} . '",' .
$self->{option_results}->{deployment} .
$self->{extra_filter} . '}, "__name__", "desired", "", "")',
'label_replace({__name__=~"' . $self->{metrics}->{current} . '",' .
@ -167,7 +183,9 @@ sub manage_selection {
$self->{extra_filter} . '}, "__name__", "unavailable", "", "")',
'label_replace({__name__=~"' . $self->{metrics}->{up_to_date} . '",' .
$self->{option_results}->{deployment} .
$self->{extra_filter} . '}, "__name__", "up_to_date", "", "")' ]);
$self->{extra_filter} . '}, "__name__", "up_to_date", "", "")'
]
);
foreach my $result (@{$results}) {
$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} = [
{ 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} = [
{ label => 'active', set => {
{ label => 'active', nlabel => 'kubernetes.namespace.active.count', set => {
key_values => [ { name => 'active' } ],
output_template => 'Active : %d',
perfdatas => [
@ -59,7 +60,7 @@ sub set_counters {
],
}
},
{ label => 'terminating', set => {
{ label => 'terminating', nlabel => 'kubernetes.namespace.terminating.count', set => {
key_values => [ { name => 'terminating' } ],
output_template => 'Terminating : %d',
perfdatas => [
@ -105,8 +106,7 @@ sub new {
bless $self, $class;
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
$options{options}->add_options(arguments => {
"namespace:s" => { name => 'namespace', default => 'namespace=~".*"' },
"phase:s" => { name => 'phase', default => 'phase=~".*"' },
"warning-status:s" => { name => 'warning_status' },
@ -153,9 +153,13 @@ sub manage_selection {
$self->{global} = { active => 0, terminating => 0 };
$self->{namespaces} = {};
my $results = $options{custom}->query(queries => [ '{__name__=~"' . $self->{metrics}->{status} . '",' .
my $results = $options{custom}->query(
queries => [
'{__name__=~"' . $self->{metrics}->{status} . '",' .
$self->{option_results}->{namespace} .
$self->{extra_filter} . '}' ]);
$self->{extra_filter} . '}'
]
);
foreach my $result (@{$results}) {
$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 $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 = ();
if ($self->{instance_mode}->{option_results}->{units} eq '%') {
$total_options{total} = $self->{result_values}->{allocatable};
@ -58,11 +57,13 @@ sub custom_usage_perfdata {
}
$self->{output}->perfdata_add(
label => $label . $extra_label,
label => $label,
nlabel => 'kubernetes.pods.allocated.count',
value => $value_perf,
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, %total_options),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, %total_options),
min => 0, max => $self->{result_values}->{allocatable}
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}, %total_options),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}, %total_options),
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};
}
$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;
}
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' } ]
value => $threshold_value, threshold => [ { label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
{ label => 'warning-'. $self->{thlabel}, exit_litteral => 'warning' } ]
);
return $exit;
}
@ -160,8 +146,7 @@ sub new {
bless $self, $class;
$self->{version} = '1.0';
$options{options}->add_options(arguments =>
{
$options{options}->add_options(arguments => {
"node:s" => { name => 'node', default => 'node=~".*"' },
"warning-status:s" => { name => 'warning_status' },
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Ready/ || %{schedulable} =~ /false/' },
@ -211,7 +196,9 @@ sub manage_selection {
$self->{nodes} = {};
my $results = $options{custom}->query(queries => [ 'label_replace({__name__=~"' . $self->{metrics}->{status} . '",' .
my $results = $options{custom}->query(
queries => [
'label_replace({__name__=~"' . $self->{metrics}->{status} . '",' .
$self->{option_results}->{node} . ',' .
'status="true"' .
$self->{extra_filter} . '}, "__name__", "status", "", "")',
@ -226,7 +213,9 @@ sub manage_selection {
$self->{extra_filter} . '}, "__name__", "allocatable", "", "")',
'label_replace({__name__=~"' . $self->{metrics}->{allocated} . '",' .
$self->{option_results}->{node} .
$self->{extra_filter} . '}, "__name__", "allocated", "", "")' ]);
$self->{extra_filter} . '}, "__name__", "allocated", "", "")'
]
);
foreach my $result (@{$results}) {
$self->{nodes}->{$result->{metric}->{$self->{labels}->{node}}}->{display} = $result->{metric}->{$self->{labels}->{node}};