mirror of
				https://github.com/centreon/centreon-plugins.git
				synced 2025-10-31 11:23:50 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			205 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			205 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
| #
 | |
| # Copyright 2016 Centreon (http://www.centreon.com/)
 | |
| #
 | |
| # Centreon is a full-fledged industry-strength solution that meets
 | |
| # the needs in IT infrastructure and application monitoring for
 | |
| # service performance.
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #     http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| #
 | |
| 
 | |
| package apps::elasticsearch::mode::cluster;
 | |
| 
 | |
| use base qw(centreon::plugins::mode);
 | |
| 
 | |
| use strict;
 | |
| use warnings;
 | |
| use centreon::plugins::http;
 | |
| use JSON;
 | |
| 
 | |
| my $thresholds = {
 | |
|     cluster => [
 | |
|         ['green', 'OK'],
 | |
|         ['yellow', 'WARNING'],
 | |
|         ['red', 'CRITICAL'],
 | |
|     ],
 | |
| };
 | |
| 
 | |
| sub new {
 | |
|     my ($class, %options) = @_;
 | |
|     my $self = $class->SUPER::new(package => __PACKAGE__, %options);
 | |
|     bless $self, $class;
 | |
| 
 | |
|     $self->{version} = '1.0';
 | |
|     $options{options}->add_options(arguments =>
 | |
|         {
 | |
|             "hostname:s"              => { name => 'hostname' },
 | |
|             "port:s"                  => { name => 'port', default => 9200 },
 | |
|             "proto:s"                 => { name => 'proto' },
 | |
|             "urlpath:s"               => { name => 'url_path', default => '/_cluster/health' },
 | |
|             "credentials"             => { name => 'credentials' },
 | |
|             "username:s"              => { name => 'username' },
 | |
|             "password:s"              => { name => 'password' },
 | |
|             "timeout:s"               => { name => 'timeout' },
 | |
|             "threshold-overload:s@"   => { name => 'threshold_overload' },
 | |
|         });
 | |
| 
 | |
|     $self->{http} = centreon::plugins::http->new(output => $self->{output});
 | |
|     return $self;
 | |
| }
 | |
| 
 | |
| sub check_options {
 | |
|     my ($self, %options) = @_;
 | |
|     $self->SUPER::init(%options);
 | |
| 
 | |
|     $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};
 | |
|     }
 | |
|     
 | |
|     $self->{http}->set_options(%{$self->{option_results}});
 | |
| }
 | |
| 
 | |
| sub get_severity {
 | |
|     my ($self, %options) = @_;
 | |
|     my $status = 'UNKNOWN'; # default
 | |
| 
 | |
|     if (defined($self->{overload_th}->{$options{section}})) {
 | |
|         foreach (@{$self->{overload_th}->{$options{section}}}) {
 | |
|             if ($options{value} =~ /$_->{filter}/i) {
 | |
|                 $status = $_->{status};
 | |
|                 return $status;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     foreach (@{$thresholds->{$options{section}}}) {
 | |
|         if ($options{value} =~ /$$_[0]/i) {
 | |
|             $status = $$_[1];
 | |
|             return $status;
 | |
|         }
 | |
|     }
 | |
|     return $status;
 | |
| }
 | |
| 
 | |
| 
 | |
| sub run {
 | |
|     my ($self, %options) = @_;
 | |
| 
 | |
|     my $jsoncontent = $self->{http}->request();
 | |
| 
 | |
|     my $json = JSON->new;
 | |
| 
 | |
|     my $webcontent;
 | |
| 
 | |
|     eval {
 | |
|         $webcontent = $json->decode($jsoncontent);
 | |
|     };
 | |
| 
 | |
|     if ($@) {
 | |
|         $self->{output}->add_option_msg(short_msg => "Cannot decode json response");
 | |
|         $self->{output}->option_exit();
 | |
|     }
 | |
| 
 | |
|     my $exit = $self->get_severity(section => 'cluster', value => $webcontent->{status});
 | |
| 
 | |
|     if ($webcontent->{status} eq 'green') {
 | |
|         $self->{output}->output_add(severity => $exit,
 | |
|                                     short_msg => sprintf("All shard are allocated for %s", $webcontent->{cluster_name}));
 | |
|     } elsif ($webcontent->{status} eq 'yellow') {
 | |
|         $self->{output}->output_add(severity => $exit,
 | |
|                                     short_msg => sprintf("Primary shards are allocated but replicas not for %s", $webcontent->{cluster_name}));
 | |
|     } elsif ($webcontent->{status} eq 'red') {
 | |
|         $self->{output}->output_add(severity => $exit,
 | |
|                                     short_msg => sprintf("Some or all primary shards aren't ready for %s", $webcontent->{cluster_name}));
 | |
|     }
 | |
| 
 | |
|     $self->{output}->perfdata_add(label => 'primary_shard',
 | |
|                                   value => sprintf("%d", $webcontent->{active_primary_shards}),
 | |
|                                   min => 0,
 | |
|     );
 | |
|     $self->{output}->perfdata_add(label => 'shard',
 | |
|                                   value => sprintf("%d", $webcontent->{active_shards}),
 | |
|                                   min => 0,
 | |
|     );
 | |
|     $self->{output}->perfdata_add(label => 'unassigned_shard',
 | |
|                                   value => sprintf("%d", $webcontent->{unassigned_shards}),
 | |
|                                   min => 0,
 | |
|     );
 | |
| 
 | |
|     $self->{output}->display();
 | |
|     $self->{output}->exit();
 | |
| 
 | |
| }
 | |
| 
 | |
| 1;
 | |
| 
 | |
| __END__
 | |
| 
 | |
| =head1 MODE
 | |
| 
 | |
| Check Elasticsearch cluster health
 | |
| 
 | |
| =over 8
 | |
| 
 | |
| =item B<--hostname>
 | |
| 
 | |
| IP Addr/FQDN of the Elasticsearch host
 | |
| 
 | |
| =item B<--port>
 | |
| 
 | |
| Port used by Elasticsearch API (Default: '9200')
 | |
| 
 | |
| =item B<--proto>
 | |
| 
 | |
| Specify https if needed (Default: 'http')
 | |
| 
 | |
| =item B<--urlpath>
 | |
| 
 | |
| Set path to get Elasticsearch information (Default: '/_cluster/health')
 | |
| 
 | |
| =item B<--credentials>
 | |
| 
 | |
| Specify this option if you access webpage over basic authentification
 | |
| 
 | |
| =item B<--username>
 | |
| 
 | |
| Specify username for API authentification
 | |
| 
 | |
| =item B<--password>
 | |
| 
 | |
| Specify password for API authentification
 | |
| 
 | |
| =item B<--timeout>
 | |
| 
 | |
| Threshold for HTTP timeout (Default: 5)
 | |
| 
 | |
| =item B<--threshold-overload>
 | |
| 
 | |
| Set to overload default threshold values (syntax: section,status,regexp)
 | |
| It used before default thresholds (order stays).
 | |
| Example: --threshold-overload='cluster,CRITICAL,^(?!(on)$)'
 | |
| 
 | |
| =back
 | |
| 
 | |
| =cut
 |