forked from HariSekhon/Nagios-Plugins
-
Notifications
You must be signed in to change notification settings - Fork 0
/
check_elasticsearch_shards_state_detail.pl
executable file
·126 lines (106 loc) · 3.44 KB
/
check_elasticsearch_shards_state_detail.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#!/usr/bin/perl -T
# nagios: -epn
#
# Author: Hari Sekhon
# Date: 2013-06-03 21:43:25 +0100 (Mon, 03 Jun 2013)
#
# https://github.com/harisekhon/nagios-plugins
#
# License: see accompanying LICENSE file
#
$DESCRIPTION = "Nagios Plugin to check the state of Elasticsearch shards not in started state, especially for unassigned shards
Tested on Elasticsearch 1.4.0 and 1.4.4";
$VERSION = "0.3.2";
use strict;
use warnings;
BEGIN {
use File::Basename;
use lib dirname(__FILE__) . "/lib";
}
use HariSekhonUtils;
use HariSekhon::Elasticsearch;
$ua->agent("Hari Sekhon $progname version $main::VERSION");
%options = (
%hostoptions,
%elasticsearch_index,
%multilineoption,
);
$options{"I|index=s"}[1] .= ", defaults to showing all indices if unspecified";
splice @usage_order, 6, 0, qw/index/;
get_options();
$host = validate_host($host);
$port = validate_port($port);
$index = validate_elasticsearch_index($index) if defined($index);
vlog2;
set_timeout();
$status = "OK";
list_elasticsearch_indices();
# This only returns STARTED shards, defeating the purpose
#my $url = "";
#$url .= "/$index" if $index;
#$url .= "/_search_shards";
#
#$json = curl_elasticsearch $url;
#
#my @shards = get_field_array("shards");
my $content = curl_elasticsearch_raw "/_cat/shards";
my %shards;
my ($index2, $shard, $prirep, $state, $docs, $store, $ip, $node);
#my $primary;
#foreach(@shards){
# foreach(@{$_}){
# $index = get_field2($_, "index");
# $shard = get_field2($_, "shard");
# $state = get_field2($_, "state");
# $primary = get_field2($_, "primary");
# $shards{$state}{$index}{$shard} = 1;
# }
#}
foreach(split("\n", $content)){
($index2, $shard, $prirep, $state, $docs, $store, $ip, $node) = split(/\s+/, $_);
next if($index and $index ne $index2);
quit "UNKNOWN", "unknown shard type '$prirep' for index '$index2'. $nagios_plugins_support_msg_api" if $prirep ne "p" and $prirep ne "r";
$shards{$state}{$index2}{$prirep}{$shard} = 1;
}
%shards or quit "UNKNOWN", "no shards found for index '$index'. Did you specify the correct index name? See --list-indices";
my $sep = ",";
$sep = "\n" if ($multiline and not $index);
my @states = keys %shards;
if(grep { "STARTED" ne $_ } @states){
foreach(@states){
if($_ eq "STARTING" or $_ eq "INITIALIZING"){
warning;
} else {
critical;
}
}
$msg = "shards not in started state: ";
foreach my $state (sort keys %shards){
next if $state eq "STARTED";
if($multiline and not $index){
$msg .= "$state:\nindex";
} else {
$msg .= "$state - index";
}
foreach $index (sort keys %{$shards{$state}}){
$msg .= " '$index' ";
foreach $prirep (sort keys %{$shards{$state}{$index}}){
if($prirep eq "p"){
$msg .= "primary ";
} elsif($prirep eq "r"){
$msg .= "replica ";
} else {
code_error "unknown shard type '$prirep' for index '$index', caught late. $nagios_plugins_support_msg_api";
}
plural keys %{$shards{$state}{$index}{$prirep}};
$msg .= "shard$plural\[" . join(",", sort { $a <=> $b } keys %{$shards{$state}{$index}{$prirep}}) . "]$sep";
}
}
$msg .= " ";
}
$msg =~ s/, $//;
} else {
$msg = "all shards in started state";
}
vlog2;
quit $status, $msg;