【教程】给Apache服务器装上轻量级的防DDoS模块

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn]

如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~

背景说明

最近我的网站在被人疯狂刷流量,导致正常访问都不行,没办法只好找找怎么给他限制一下。

apache自带有一个防刷模块mod_evasive,它是"轻度防御",适合防止刷流量/秒刷请求,不是专门防 DDoS 的完整方案。不过也能缓解一下了,毕竟轻量不臃肿。

开启模块

1、安装模块

bash 复制代码
sudo apt update
sudo apt install libapache2-mod-evasive

2、启用模块

bash 复制代码
sudo a2enmod evasive
sudo systemctl restart apache2

3、创建日志目录

bash 复制代码
sudo mkdir /var/log/mod_evasive
sudo chown www-data:www-data /var/log/mod_evasive

4、配置 mod_evasive

bash 复制代码
sudo vim /etc/apache2/mods-available/evasive.conf

配置示例:

bash 复制代码
<IfModule mod_evasive20.c>
    DOSHashTableSize    3097
    DOSPageCount        5
    DOSSiteCount        30
    DOSPageInterval     1
    DOSSiteInterval     1
    DOSBlockingPeriod   600

    DOSEmailNotify      you@example.com
    DOSSystemCommand    "sudo iptables -A INPUT -s %s -j DROP"
    DOSLogDir           "/var/log/mod_evasive"
</IfModule>

参数说明:

参数 说明
DOSPageCount 同一个 IP 在多少秒内访问同一个 URL 超过几次就触发(默认建议 2~5)
DOSSiteCount 同一个 IP 在多少秒内访问整个站点总次数限制
DOSPageInterval 页面请求间隔时间(秒)
DOSSiteInterval 站点请求间隔时间(秒)
DOSBlockingPeriod 触发封锁后禁止访问时间(秒)
DOSEmailNotify 可选:触发时通知管理员
DOSSystemCommand 可选:触发时执行系统命令(比如 iptables 封禁)
DOSLogDir 日志目录(必须存在)

我的服务器是2核2G,带宽为4M。我用的配置是:

bash 复制代码
<IfModule mod_evasive20.c>
    DOSHashTableSize    3097

    # 单 IP 每秒访问同一页面超过 3 次就触发(适用于刷图片、下载)
    DOSPageCount        3
    DOSPageInterval     1

    # 单 IP 每秒对整个站点访问总次数限制为 20(足够浏览页面)
    DOSSiteCount        20
    DOSSiteInterval     1

    # 触发封锁后封禁 600 秒(10 分钟)
    DOSBlockingPeriod   600

    # 日志目录(需要提前创建)
    DOSLogDir           "/var/log/mod_evasive"

    # 可选:邮件通知(改成你自己的邮箱)
    # DOSEmailNotify      your@email.com

    # 封禁命令(也可以注释掉,仅限拒绝请求)
    DOSSystemCommand    "sudo iptables -I INPUT -s %s -j DROP"
</IfModule>

5、重启 Apache 生效

bash 复制代码
sudo systemctl restart apache2

效果展示

效果还是有一点的,至少带宽不会被一直占着了,肉眼可见的流量拦截:

相关推荐
cui_ruicheng2 分钟前
Linux信号机制(一):从概念到产生与处理
linux·运维·服务器
KnowSafe2 小时前
从手动到智能:证书自动化解决方案的技术演进
运维·自动化
墨风如雪8 小时前
甲骨文云(Oracle Cloud)最新注册防坑记录:被ABC了怎么办?
服务器
xingfujie9 小时前
运维实战攻略
运维
道清茗9 小时前
【RH294知识点汇总】第 9 章 《 自动执行 Linux 管理任务 》常见问题
linux·运维·服务器
北方的流星9 小时前
华三路由器NAT配置
运维·网络·华三
wj30558537810 小时前
Codex + Git 开发环境配置指南(WSL版)
linux·运维·git
星马梦缘10 小时前
如何切换window-ubuntu双系统【方案二】
linux·运维·ubuntu
2501_9272835811 小时前
荣联汇智助力天津艺虹打造“软硬一体”智慧工厂,全流程自动化引领印刷包装行业数智变革
大数据·运维·数据仓库·人工智能·低代码·自动化
HXDGCL11 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化