-
Notifications
You must be signed in to change notification settings - Fork 57
/
Copy pathcheck_topology-spouts
executable file
·185 lines (171 loc) · 4.12 KB
/
check_topology-spouts
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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
#!/bin/bash
showhelp () {
cat <<eof
Check to see if the defined amount of spouts are actually running.
Parameters:
--topology-name | -n : The name of the topology
--spout-name | -s : The name of the spout to check, if not specified, it will print a list of spouts
--url | -u : The url to connect to storm, defaults to localhost:8080
--expected-par | -p : The expected amount of spout instances, defaults to 1
--help | -h : Shows help
--debug | -d : Enable debugging, aka echo some params
Example usage:
./check_topology_spouts -n intercad-topology -b update_incident_spout
eof
exit 3
}
debug () {
if $debug
then
echo $@
fi
}
# Params
defaults () {
# Not specified params
error_spouts=''
good_spouts=0
# Required params
if [[ -z "${topology_name}" ]]
then
message="Unknown: You need to specify --topology-name of use --help"
exitstatus='3'
quit
fi
# Optional params
if [[ -z "${url}" ]]
then
url='localhost:8080'
fi
if [[ -z "${debug}" ]]
then
debug=false
fi
if [[ -z "${expected_par}" ]]
then
expected_par='1'
fi
if [[ -z "${spout_name}" ]]
then
spout_name='ALL'
fi
}
is_spout_id_defined () {
spout_id_test=$@
spout_ids=$( echo $get_spouts | jq ".spouts[].spoutId" -r )
return_value=1
for element in $spout_ids
do
debug 'Checking if spout_id is defined'
if [ $element == $spout_id_test ]
then
return_value=0
debug 'it is!'
break
fi
done
return $return_value
}
get_data () {
# Get the id of the topology
get_topology_id=$( curl -s http://${url}/api/v1/topology/summary )
# Check if the topology_name is defined
get_topologies_specified=$( echo $get_topology_id | jq ".topologies[].id" -r )
debug $get_topologies_specified
if [[ -z $get_topologies_specified ]]
then
message="Error: Topology ${topology_name} not defined"
exitstatus='2'
quit
fi
topology_id=$( echo $get_topology_id | jq ".topologies | map(select(.name == \"${topology_name}\" )) | .[].id" -r )
debug $topology_id
debug "curl -s http://${url}/api/v1/topology/${topology_id}"
get_spouts=$( curl -s http://${url}/api/v1/topology/${topology_id} )
if [[ "$spout_name" == "ALL" ]]
then
message="Unknown: Available spouts:\n"
spout_ids=$( echo $get_spouts | jq ".spouts[].spoutId" -r )
message="${message}${spout_ids}"
exitstatus="3"
quit
else
spout_id=$spout_name
fi
}
do_main_check_one () {
# Check if the spout is defined in the topology
if is_spout_id_defined $spout_id
then
# Get data on the spout
get_spout_tasks=$( echo $get_spouts | jq " .spouts | map(select(.spoutId == \"${spout_id}\" )) | .[].tasks" -r )
get_spout_last_error=$( echo $get_spouts | jq " .spouts | map(select(.spoutId == \"${spout_id}\" )) | .[].lastError" -r )
get_spout_executors=$( echo $get_spouts | jq " .spouts | map(select(.spoutId == \"${spout_id}\" )) | .[].executors" -r )
debug ==============
debug $spout_id
debug $get_spout_tasks
debug $get_spout_executors
if [[ ! -z $get_spout_last_error ]]
then
debug $get_spout_last_error
else
debug No lastError
fi
debug ==============
# Do the actual check
if [[ $get_spout_tasks == $expected_par ]]
then
message="Ok: Spout: ${spout_name} is running $get_spout_tasks tasks."
exitstatus='0'
else
message="Critical: Spout: ${spout_name} is running $get_spout_tasks tasks!"
exitstatus='2'
fi
else
message="Critical: Spout not found!"
exitstatus='2'
fi
}
quit () {
echo -e "${message}" && exit $exitstatus
}
# Start casing
while test -n "$1"
do
case "$1" in
--help|-h)
showhelp
;;
--topology-name|-n)
shift
topology_name=$1
shift
;;
--url|-u)
shift
url=$1
shift
;;
--debug|-d)
shift
debug=true
;;
--expected-par|-p)
shift
expected_par=$1
shift
;;
--spout-name|-s)
shift
spout_name=$1
shift
;;
*)
showhelp
;;
esac
done
defaults
get_data
do_main_check_one
quit