-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathtrafstat.sh
40 lines (32 loc) · 1.51 KB
/
trafstat.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
#!/bin/bash
FILES="$*"
DIR=`date +'%Y%m%d_%H%M'`
THOLD=10
for i in $FILES
do
if [ ! -f $i ]; then
echo "No such file $i"
exit 1
fi
done
mkdir -p $DIR
echo "Saving in $DIR"
ACLS=`cat $FILES | egrep permitted | egrep access-list | sed -e 's/^.*access-list //' | awk '{acl[$1]++;} END { for ( i in a
cl ) printf("%s %d %d %d %d %d\n",i,acl[i],acl[i]/10000,acl[i]/5000,acl[i]/1000,acl[i]/500);}' | tee ${DIR}/acl.stat | awk '{print $1}'`
echo "ACL Count 0.01% 0.02% 0.1% 0.2%"
cat ${DIR}/acl.stat
for i in $ACLS
do
echo $i
# output format:
# count source_IP destination_IP protocol:port
# sorted in the descending order
cat $FILES | egrep -v icmp | egrep "access-list $i permitted" | sed -e 's/^.*permitted //' | sed -e 's/ hit-cnt.*$//' | sed -e 's%(.
*/% %' | sed -e 's/^ //' | sed -e 's% .*/% %' | sed -e 's/(\(.*\))/ \1/' | awk '{ if ($4 < 32768) {conn[$0]++;} } END { for ( i in conn ) print conn[i],"",i;}'
| sort +0nr | awk '{printf("%d %s %s %s:%d\n",$1,$3,$4,$2,$5);}' > ${DIR}/$i
set `grep $i ${DIR}/acl.stat`
cat ${DIR}/$i | awk ' {conn[$2] += $1;} END {for ( i in conn ) print conn[i],"",i;}' | sort +0nr > ${DIR}/${i}.tops
cat ${DIR}/$i | awk ' {conn[$3] += $1;} END {for ( i in conn ) print conn[i],"",i;}' | sort +0nr > ${DIR}/${i}.topd
cat ${DIR}/$i | awk ' { if ($1 >'$THOLD') {print $0}}' > ${DIR}/${i}.$THOLD
cat ${DIR}/$i | awk ' { if ($1 >'$3') {print $0}}' > ${DIR}/${i}.$3
done