-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapacheIPcount.bash
executable file
·124 lines (96 loc) · 2.85 KB
/
apacheIPcount.bash
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
#!/usr/bin/env bash
START=$(date +%s.%N)
arg1=${1:-''}
if [[ $arg1 == '--help' || $arg1 == '-h' ]]; then
echo "$0 pathToAccessLog [threshold] (default 500)"
exit 0
fi
#exit when command fails (use || true when a command can fail)
set -o errexit
#exit when your script tries to use undeclared variables
set -o nounset
# in scripts to catch mysqldump fails
set -o pipefail
# Resolve first directory of script
PRG="$BASH_SOURCE"
progname=`basename "$BASH_SOURCE"`
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG=`dirname "$PRG"`"/$link"
fi
done
__dir=$(dirname "$PRG")
# Set magic variables for current file & dir
__root="$(cd "$(dirname "${__dir}")" && pwd)" # Dir of the dir of the script
__file="${__dir}/$(basename "${BASH_SOURCE[0]}")" # Full path of the script
__base="$(basename ${__file})" # Name of the script
ts=`date +'%Y%m%d-%H%M%S'`
ds=`date +'%Y%m%d'`
pid=`ps -ef | grep ${__base} | grep -v 'vi ' | head -n1 | awk ' {print $2;} '`
formerDir=`pwd`
apacheLogPath=$1
threshold=${2:-500}
#POSITIONAL=()
#while [[ $# -gt 0 ]]
#do
#key="$1"
#
#case $key in
# -a|--accessLog)
# apacheLogPath="$2"
# shift # past argument
# shift # past value
# ;;
# -t|--threshold)
# threshold="$2"
# shift # past argument
# shift # past value
# ;;
# *) # unknown option
# POSITIONAL+=("$1") # save it in an array for later
# shift # past argument
# ;;
#esac
#done
#set -- "${POSITIONAL[@]}" # restore positional parameters
#Set the config file
configFile="$HOME/.binJlam/templateConfig"
#Capture everything to log
mkdir -p ~/log
log=~/log/$__base-${ts}.log
exec > >(tee -a $log)
exec 2> >(tee -a $log >&2)
touch $log
chmod 600 $log
#Check that the config file exists
#if [[ ! -f "$configFile" ]] ; then
# echo "I need a file at $configFile with ..."
# exit 1
#fi
export DISPLAY=:0
echo Begin `date` .....
echo; echo; echo;
### BEGIN SCRIPT ###############################################################
#(a.k.a set -x) to trace what gets executed
# Credit: https://encodable.com/tech/blog/2008/12/17/Count_IP_Addresses_in_Access_Log_File_BASH_OneLiner
FILE="$apacheLogPath"
for ip in `cat $FILE |cut -d ' ' -f 1 |sort |uniq`;
do { COUNT=`grep ^$ip $FILE |wc -l`;
if [[ "$COUNT" -gt "$threshold" ]]; then echo "$COUNT : $ip";
fi }; done | sort -n -k 1
set +x
### END SCIPT ##################################################################
cd $formerDir
END=$(date +%s.%N)
DIFF=$(echo "round($END - $START)" )
echo; echo; echo;
echo Done. `date` - $DIFF seconds
#=== BEGIN Unique instance ============================================
if [ -f ${pidfile} ]; then
rm ${pidfile}
fi
#=== END Unique instance ============================================