forked from HariSekhon/Nagios-Plugins
-
Notifications
You must be signed in to change notification settings - Fork 0
/
check_cloudera_manager_health.pl
executable file
·114 lines (93 loc) · 2.86 KB
/
check_cloudera_manager_health.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
#!/usr/bin/perl -T
# nagios: -epn
#
# Author: Hari Sekhon
# Date: 2013-11-14 11:58:18 +0000 (Thu, 14 Nov 2013)
# redo 2014-04-13 19:45:41 +0100 (Sun, 13 Apr 2014)
#
# http://github.com/harisekhon/nagios-plugins
#
# License: see accompanying LICENSE file
#
# still calling v1 for compatability with older CM versions
#
# http://cloudera.github.io/cm_api/apidocs/v1/index.html
$DESCRIPTION = "Nagios Plugin to check service/role/host health in Cloudera Manager via CM Rest API
You may need to upgrade to Cloudera Manager 4.6 for the Standard Edition (free) to allow the API to be used, but it should work on all versions of Cloudera Manager Enterprise Edition
This is still using v1 of the API for compatability purposes
Tested on Cloudera Manager 5.0.0";
$VERSION = "0.3";
use strict;
use warnings;
BEGIN {
use File::Basename;
use lib dirname(__FILE__) . "/lib";
}
use HariSekhonUtils;
use HariSekhon::ClouderaManager;
$ua->agent("Hari Sekhon $progname version $main::VERSION");
%options = (
%hostoptions,
%useroptions,
%cm_options,
%cm_options_list,
);
delete $options{"activityId=s"};
delete $options{"N|nameservice=s"};
@usage_order = qw/host port user password tls ssl-CA-path tls-noverify cluster service hostId activityId nameservice roleId CM-mgmt list-activities list-clusters list-hosts list-nameservices list-roles list-services/;
get_options();
$host = validate_host($host);
$port = validate_port($port);
$user = validate_user($user);
$password = validate_password($password);
vlog2;
set_timeout();
$status = "OK";
list_cm_components();
if($cm_mgmt){
$url .= "$api/cm/service";
if($cluster or $service or $hostid){
usage "cannot mix --cluster/--service/--host and --CM-mgmt";
}
if(defined($role)){
$url .= "/roles/$role";
}
} else {
validate_cm_cluster_options();
}
cm_query();
check_cm_field("healthSummary");
my $health = $json->{"healthSummary"};
if(($cluster and $service) or $cm_mgmt){
if($cm_mgmt){
$msg = "Cloudera Manager Mgmt service";
} else {
$msg = "cluster '$cluster' service '$service'";
}
if($role){
check_cm_field("type");
if($verbose){
$msg .= " role '$role'";
} else {
$msg .= " role '" . $json->{"type"} . "'";
}
}
} elsif($hostid){
$msg = "host '$hostid'";
} else {
usage "must specify --hostId, or --cluster/--service or --CM-mgmt and optionally --role";
}
$msg .= " health=$health";
if($health eq "GOOD"){
# ok
} elsif(grep { $health eq $_ } qw/CONCERNING/){
warning;
} elsif(grep { $health eq $_ } qw/BAD DISABLED/){ # DISABLED implies STOPPED state
critical;
} elsif(grep { $health eq $_ } qw/UNKNOWN NOT_AVAILABLE HISTORY_NOT_AVAILABLE/){
unknown;
} else {
unknown;
$msg .= " (health unrecognized. $nagios_plugins_support_msg_api)";
}
quit $status, $msg;