Apache模块mod_evasive利用Hash表储存相应的HTTP请求,利用设定规则判断是否拒绝对方的请求。
mod_evasive于2010年推出,适用于Apache v1.3 、2.0;没有后续更新。
官网:http://www.zdziarski.com/blog/?page_id=442
下载:http://www.zdziarski.com/blog/wp-content/uploads/sites/2/old/2010/02/mod_evasive_1.10.1.tar.gz
参考:http://www.haiyun.me/archives/httpd-mod-evasive-ddos
参考:https://vultrgiftcodes.com/%e5%9c%a8-apache-mod_evasive
编译、安装、并加载模块:
wget http://www.zdziarski.com/blog/wp-content/uploads/sites/2/old/2010/02/mod_evasive_1.10.1.tar.gz tar zxvf mod_evasive_1.10.1.tar.gz && cd mod_evasive/ apxs -i -a -c mod_evasive20.c
配置mod_evasive:
<IfModule mod_evasive20.c>
DOSHashTableSize 3097 #表大小
DOSPageCount 2 #限制单位时间内同一IP请求同一网页次数
DOSSiteCount 10 #限制单位时间内同一IP请求网站次数
DOSPageInterval 1 #网页存取间隔
DOSSiteInterval 1 #网站存取间隔
DOSBlockingPeriod 10 #限制访问时间
DOSEmailNotify #疑似攻击时邮件通知
DOSSystemCommand "su - onovps -c iptables -I INPUT -s %s --dport 80 -j DROP"
#疑似攻击时用防火墙限制IP访问80端口
DOSLogDir "/var/log/ #日志目录
DOSWhiteList 127.0.0.1 #添加白名单
</IfModule>
重启Apache生效:
/etc/init.d/httpd restart
同时作者还提供了一个测试程序用以测试mod_evasive是否生效:
perl test.pl HTTP/1.1 200 OK HTTP/1.1 403 Forbidden