linux用shell腳本解决被ddos攻击的问题
最近网站常常被人DDOS所以写了一个小程序用来自动封锁IP,代码如下:
!/bin/bash
for (( ; ; ))
do
status=netstat -na|grep ESTABLISHED|awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -rn|head -10|grep -v -E '127.0|192.168|118.163.81|66.249|125.227.190'
if [[ ${#status} > 0 ]]; then
NUM=echo $status|awk '{print $1}'
IP=echo $status|awk '{print $3}'
result=echo "$NUM > 150" | bc
echo $result '|' $IP '|' $NUM
if [[ $result = 1 ]] && [[ ${#IP} > 0 ]]; then
echo $IP '=>' $NUM
/sbin/iptables -I INPUT -s $IP -j DROP
fi
fi
sleep 30
done
把上边的代码存成autorun.sh,然后增加执行权限,放入到开机启动项里,重新启动服务器即可
以后他就会自动每间隔30秒侦测一下是否被人攻击,一旦发现立即封锁IP