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

posted @ 2015-12-15 15:54  PHP群:223494678  阅读(749)  评论(0编辑  收藏