forked from apisec-inc/apisec-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapisec-k8s-logs-capture.sh
More file actions
84 lines (63 loc) · 2.18 KB
/
apisec-k8s-logs-capture.sh
File metadata and controls
84 lines (63 loc) · 2.18 KB
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
#!/bin/bash
# Begin
# Script Purpose: This script will capture log messages based on user defined keywords if those log message present in the pods.
#
#
# How to run the this script.
# Syntax: bash apisec-k8s-logs-capture.sh --logMessage "<log message to be captured>"
# Example usage: bash apisec-k8s-logs-capture.sh --logMessage "exception"
# Note!!! 1. This script needs to be run against a running k8s cluster from bash shell prompt.
# 2. This script will create a directory named "log-messages" in the present working directory and store all the captured log messages
# files of the respective pods in that directory.
# 3. Please make sure linux user thorugh whom this script will be run have appropriate permissions for a directory from present working directory.
# 4. If no --logMessage parameter is passed during the script execution time, then 'exception' key-word log messages will be captured by default.
# Eg: bash apisec-logs-capture.sh
TEMP=$(getopt -n "$0" -a -l "logMessage:" -- -- "$@")
[ $? -eq 0 ] || exit
eval set -- "$TEMP"
while [ $# -gt 0 ]
do
case "$1" in
--logMessage) LOG_MESSAGE="$2"; shift;;
--) shift;;
esac
shift;
done
if [ "$LOG_MESSAGE" = "" ];
then
LOG_MESSAGE="exception"
fi
echo "Checking $LOG_MESSAGE log messages!!"
sleep 5
if [ -d "log-messages" ]; then
echo "Directory 'log-messages' exits!!"
ls
echo " "
else
ls
echo "Directory 'log-messages' doesn't exists, will create it!!"
mkdir log-messages
ls
fi
sleep 10
podIds=$(kubectl get po | awk '{print $1}' | sed -n '1d;p')
echo " "
echo "$podIds"
echo " "
for id in ${podIds}
do
dat=$(date "+%F-%H%M%S")
logs=$(kubectl logs $id | grep $LOG_MESSAGE)
if [ "$logs" = "" ]; then
echo "No $LOG_MESSAGE message in $id pod!"
echo " "
else
echo "$logs" >> log-messages/$id-$LOG_MESSAGE-logs-$dat.txt
ls log-messages
echo " "
fi
done
echo " "
ls log-messages
echo " "
echo "Script Execution is completed!!"