#! /bin/bash
cat /var/log/secure|awk '/Failed/{print $(NF-3)}'|awk -F ":" '{print $4}'|sort|uniq -c|awk '{print $2"="$1;}' > /tmp/denyhosts
#cat /var/log/secure|awk '/Invalid user/{print $NF}'|awk -F ":" '{print $4}'|sort|uniq -c|awk '{print $2"="$1;}' >> /tmp/denyhosts
hosts=`cat /etc/hosts.deny|awk -F : '{print $2}'`
TIMES="5"
AB='111.111.111.111'
CD='222.222.222.222'
for i in `cat /tmp/denyhosts`
do
IP=`echo $i |awk -F= '{print $1}'`
NUM=`echo $i|awk -F= '{print $2}'`
if [ $NUM -gt $TIMES ];
then
grep $IP /etc/hosts.deny > /dev/null
if [ $? -gt 0 ];
then
echo ok;
if [ "$IP" == "$AB" ] || [ "$IP" == "$CD" ]
then
exit;
else
echo "sshd:$IP" >> /etc/hosts.deny
fi
fi
fi
done
本文介绍了一个Bash脚本,该脚本通过解析/var/log/secure日志文件来统计失败的SSH登录尝试,并根据预设次数将频繁尝试连接的IP地址加入到/etc/hosts.deny文件中以阻止其进一步的连接尝试。此外,脚本还包含了一些条件判断以避免误封某些特定IP。
373

被折叠的 条评论
为什么被折叠?



