收集 /var/log/secure 里面的信息,若是某个IP 链接次数超过一定次数 ,则把此ip记录到/etc/hosts.deny里面

#!/bin/bash
#Denyhosts SHELL SCRIPT
#2013-6-24
cat /var/log/secure|awk '/Failed/{print $(NF-3)}'|sort|uniq -c|awk '{print $2"=" $1;}' >/usr/local/bin/Denyhosts.txt
DEFINE="10"
for i in `cat /usr/local/bin/Denyhosts.txt`
do 
        IP=`echo $i|awk -F= '{print $1}'`
        NUM=`echo $i|awk -F= '{print $2}'`
        if [ $NUM -gt $DEFINE ]
        then
                grep $IP /etc/hosts.deny >/dev/null
                if [ $? -gt 0 ];
                then
                echo "sshd:$IP" >> /etc/hosts.deny
                fi
        fi
done

 

添加到定时任务
crontab -e
添加定时任务
*/2 * * * * /usr/local/bin/denyhosts.sh
执行启动
/sbin/service crond start

 

相关文章:

  • 2021-12-31
  • 2022-01-09
  • 2021-07-25
  • 2021-10-07
  • 2022-12-23
  • 2021-08-07
  • 2022-02-01
猜你喜欢
  • 2021-09-29
  • 2021-12-07
  • 2021-06-02
  • 2022-12-23
  • 2021-11-13
  • 2021-12-31
  • 2021-08-23
相关资源
相似解决方案