forked from eldada/kubernetes-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
getPodsTopCSV.sh
executable file
·204 lines (173 loc) · 5.65 KB
/
getPodsTopCSV.sh
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
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
#!/bin/bash
# UNCOMMENT this line to enable debugging
# set -xv
## Get formatted results of kubectl top pod --containers
OUT=top-$(date +"%Y-%m-%d_%H:%M:%S").csv
NAMESPACE=--all-namespaces
QUITE=false
HEADERS=true
SCRIPT_NAME=$0
DURATION=0
INTERVAL=5
POD=
CONTAINERS=
######### Functions #########
errorExit () {
echo -e "\nERROR: $1\n"
exit 1
}
usage () {
cat << END_USAGE
${SCRIPT_NAME} - Get formatted results of kubectl top pod in a Kubernetes cluster for a selected namespace and pod in a CSV format
Usage: ${SCRIPT_NAME} <options>
-n | --namespace <name> : Namespace to analyse. Default: default
-p | --pod <name> : Pod to analyse.
-d | --duration <seconds> : Duration of sampling. Default: ${DURATION} (infinite)
-i | --interval <seconds> : Interval between samples. Default: ${INTERVAL}
-o | --output <name> : Output file. Default: top-<timestamp>.csv
-c | --containers : Output per container. Default: off
-q | --quite : Don't output to screen. Default: Output to screen
-h | --help : Show this usage
--no-headers : Don't print headers line
Examples:
========
Get for pod foo in namespace bar: $ ${SCRIPT_NAME} --namespace bar --pod foo
Get for pod foo in namespace bar and output to file foo.csv : $ ${SCRIPT_NAME} --namespace bar --pod foo --output foo.csv
END_USAGE
exit 1
}
# Process command line options. See usage above for supported options
processOptions () {
while [[ $# -gt 0 ]]; do
case "$1" in
-n | --namespace)
NAMESPACE="--namespace $2"
shift 2
;;
-p | --pod)
POD="$2"
shift 2
;;
-d | --duration)
DURATION="$2"
shift 2
;;
-i | --interval)
INTERVAL="$2"
shift 2
;;
-o | --output)
OUT=$2
shift 2
;;
-c | --containers)
CONTAINERS="--containers"
shift 1
;;
-q | --quite)
QUITE=true
shift 1
;;
--no-headers)
HEADERS=false
shift 1
;;
-h | --help)
usage
exit 0
;;
*)
usage
;;
esac
done
[ -z "${POD}" ] && errorExit "Must provide pod name (--pod <POD>)"
}
# Test connection to a cluster by kubectl
testConnection () {
kubectl cluster-info > /dev/null || errorExit "Connection to cluster failed"
kubectl get pod ${NAMESPACE} "${POD}" > /dev/null || errorExit "Pod ${POD} not found in namespace ${NAMESPACE}"
}
formatCpu () {
local result=$1
if [[ ${result} =~ m$ ]]; then
result=$(echo "${result}" | tr -d 'm')
result=$(awk "BEGIN {print ${result}/1000}")
fi
echo -n "${result}"
}
formatMemory () {
local result=$1
if [[ ${result} =~ M ]]; then
result=$(echo "${result}" | tr -d 'Mi')
result=$(awk "BEGIN {print ${result}/1000}")
elif [[ ${result} =~ m ]]; then
result=$(echo "${result}" | tr -d 'm')
result=$(awk "BEGIN {print ${result}/1000000000000}")
elif [[ ${result} =~ G ]]; then
result=$(echo "${result}" | tr -d 'Gi')
fi
echo -n "${result}"
}
getPodsTop () {
local condition=true
local counter=0
local line=
local time_stamp=
local cpu=
local memory=
if [ "${DURATION}" != 0 ]; then
condition="[]"
fi
while ${condition}; do
line=$(kubectl top pod ${NAMESPACE} "${POD}" --no-headers ${CONTAINERS} --use-protocol-buffers)
# echo "--- $line"
local final_line=
# Go over all the containers
local OLD_IFS=${IFS}
IFS=$'\n'
for l in ${line}; do
local container=""
local header="Timestamp,Pod,CPU (cores),Memory (GB)"
time_stamp=$(date +"%Y-%m-%d_%H:%M:%S")
if [ -n "${CONTAINERS}" ]; then
container=$(echo "${l}" | awk '{print $2}')
cpu=$(formatCpu "$(echo "${l}" | awk '{print $3}')")
memory=$(formatMemory "$(echo "${l}" | awk '{print $4}')")
header="Timestamp,Pod,Container,CPU (cores),Memory (GB)"
else
cpu=$(formatCpu "$(echo "${l}" | awk '{print $2}')")
memory=$(formatMemory "$(echo "${l}" | awk '{print $3}')")
fi
local out_file=${OUT}
# Print header in each file if this is the first line
if [ ${counter} -eq 0 ]; then
if [ "${HEADERS}" == true ]; then
echo "${header}" > "${out_file}"
else
echo -n "" > "${out_file}"
fi
fi
final_line=${time_stamp},${POD},${cpu},${memory}
if [ -n "${CONTAINERS}" ]; then
final_line=${time_stamp},${POD},${container},${cpu},${memory}
fi
if [ "${QUITE}" == true ]; then
echo "${final_line}" >> "${out_file}"
else
echo "${final_line}" | tee -a "${out_file}"
fi
done
IFS=${OLD_IFS}
sleep "${INTERVAL}"
(( counter++ ))
done
}
main () {
processOptions "$@"
[ "${QUITE}" == true ] || echo "Getting Pod memory and cpu usage"
testConnection
getPodsTop
}
######### Main #########
main "$@"