From 3b0d26708c0b1f6c8dd168c7d10904cc117948b7 Mon Sep 17 00:00:00 2001 From: Mathieu Cinquin Date: Thu, 16 Apr 2015 10:32:08 +0200 Subject: [PATCH] Refs #6339 - Add threshold overload --- apps/elasticsearch/mode/indice.pm | 39 ++++++++++++++++++++++++------- 1 file changed, 31 insertions(+), 8 deletions(-) diff --git a/apps/elasticsearch/mode/indice.pm b/apps/elasticsearch/mode/indice.pm index 7b375f586..48cc57769 100644 --- a/apps/elasticsearch/mode/indice.pm +++ b/apps/elasticsearch/mode/indice.pm @@ -64,14 +64,15 @@ sub new { $self->{version} = '1.0'; $options{options}->add_options(arguments => { - "hostname:s" => { name => 'hostname' }, - "port:s" => { name => 'port', default => '9200'}, - "proto:s" => { name => 'proto', default => 'http' }, - "urlpath:s" => { name => 'url_path', default => '/' }, - "credentials" => { name => 'credentials' }, - "username:s" => { name => 'username' }, - "password:s" => { name => 'password' }, - "timeout:s" => { name => 'timeout', default => '3' }, + "hostname:s" => { name => 'hostname' }, + "port:s" => { name => 'port', default => '9200'}, + "proto:s" => { name => 'proto', default => 'http' }, + "urlpath:s" => { name => 'url_path', default => '/' }, + "credentials" => { name => 'credentials' }, + "username:s" => { name => 'username' }, + "password:s" => { name => 'password' }, + "timeout:s" => { name => 'timeout', default => '3' }, + "threshold-overload:s@" => { name => 'threshold_overload' }, }); return $self; @@ -89,6 +90,22 @@ sub check_options { $self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used"); $self->{output}->option_exit(); } + + $self->{overload_th} = {}; + foreach my $val (@{$self->{option_results}->{threshold_overload}}) { + if ($val !~ /^(.*?),(.*?),(.*)$/) { + $self->{output}->add_option_msg(short_msg => "Wrong treshold-overload option '" . $val . "'."); + $self->{output}->option_exit(); + } + my ($section, $status, $filter) = ($1, $2, $3); + if ($self->{output}->is_litteral_status(status => $status) == 0) { + $self->{output}->add_option_msg(short_msg => "Wrong treshold-overload status '" . $val . "'."); + $self->{output}->option_exit(); + } + $self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section})); + push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status}; + } + } sub get_severity { @@ -192,6 +209,12 @@ Specify username for API authentification Specify password for API authentification +=item B<--threshold-overload> + +Set to overload default threshold values (syntax: section,status,regexp) +It used before default thresholds (order stays). +Example: --threshold-overload='indices,CRITICAL,^(?!(on)$)' + =item B<--timeout> Threshold for HTTP timeout (Default: 3)