|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
如果您觉得本篇CentOSLinux教程讲得好,请记得点击右边漂浮的分享程序,把好文章分享给你的小伙伴们!比来办事器频仍遭到CC打击,抓包、剖析毗连数后,发明单台办事器的并发毗连数到达5万多,本想使用iptables的connlimit模块对毗连数据举行限定的,无法我接办的这几台办事器都没打此补钉,决意使用shell剧本关于一些毗连数过年夜的IP举行屏障
vi/opt/drop_tcp.sh
#!/bin/sh
netstat-nat-n>/opt/netstat-net.log
file=/opt/drop_ip.log
//判别毗连数年夜于20的IP
/bin/awk-F:/tcp/{a[$(NF-2)]++}END{for(iina)if(a[i]>20)printi}/opt/netstat-net.log>$file
drop_ip=`cat$file|awk{print$2}`
foriptables_ipin$drop_ip
do
//假如iptables的PREROUTING链中,没有呈现过这个IP,则间接用iptables抛弃一切来自这个IP地点发送的哀求
if[$iptables_ip!=$0]&&[-z"`iptables-nvL-tnat|grep$iptables_ip`"];then
/sbin/iptables-tnat-IPREROUTING-s$iptables_ip-jDROP
fi
done
//按期实行此剧本
crontab-e
*/5****sh/opt/drop_tcp.sh
如许关于单IP毗连数凌驾20的举行屏障
为了不iptables划定规矩过于痴肥,也要对已屏障IP举行解封
vi/opt/drop_iptables.sh
#!/bin/sh
iptables=/opt/iptables.log
iptables-save>$iptables
drop_ip1=`cat$iptables|awk/DROP/{print$4}`
foriptables_ip1in$drop_ip1
do
/sbin/iptables-tnat-DPREROUTING-s$iptables_ip1-jDROP
done
//按期实行此剧本
crontab-e
**/3***sh/opt/drop_iptables.sh
如果您觉得本篇CentOSLinux教程讲得好,请记得点击右边漂浮的分享程序,把好文章分享给你的小伙伴们! |
|