一个简单的防CC攻击Shell脚本分享
实现代码:
代码如下:
#!/bin/sh cd /var/log/httpd/ cat access_log|awk '{print $1}'|sort|uniq -c|sort -n -r|head -n 20 > a cp /dev/null access_log cp /dev/null error_log cp /dev/null limit.sh cp /dev/null c #awk '{print $2}' a|awk -F. '{print $1"."$2"."$3}'|sort|uniq > b cat a|while read num ip do if [ "$num" -gt "20" ] then echo $ip >> c fi done cat c|awk -F. '{print $1"."$2"."$3}'|sort|uniq > b #cat c|sort|uniq > b for i in `cat b` #cat b|sed 's/\./ /g'|while read i1 i2 i3 i4 do if `cat ourip |grep $i > /dev/null 2>&1` then echo "`date` $i" >> test else echo "iptables -I INPUT -p tcp -dport 80 -s $i.0/24 -j DROP" >> limit.sh fi done
使用方法,运行命令:sh limit.sh,这样就会把访问量过高的IP加入防火墙,并禁止访问
相关推荐
老男孩linux教育 2010-03-05
ScienceExplorer 2010-12-20
常言道 2020-05-25
Summer的小屋 2013-08-13
前端知识梳理 2019-11-01
展翅飞嵌入式之路 2017-03-24
xasdfg 2015-08-01
hedafighter0 2015-12-20
ARCHYang 2015-04-22
yunna0 2019-06-26
xasdfg 2012-04-29
Eleven的个人小站 2014-09-20
89284553 2014-03-12
yuanheiqng 2014-04-10
fengxu 2018-02-20
BillyThe 2016-01-06
迷题 2015-04-06
rise 2015-08-18
wmengbeyond 2012-04-21