【教程】给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

效果展示

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

相关推荐
linT_T2 分钟前
研发团队看板协作中的自动化实践:集成CI/CD与任务流转
运维·ci/cd·自动化
中科米堆3 分钟前
中科米堆CASAIM自动化三维扫描系统自动测量压铸件尺寸
运维·自动化·视觉检测
小嵌同学9 分钟前
Meson:开源的自动化构建系统
linux·运维·开源·自动化·meson
果子⌂35 分钟前
Zabbix 企业级高级应用
linux·运维·nginx·zabbix
钱彬 (Qian Bin)42 分钟前
解决docker load加载tar镜像报json no such file or directory的错误
运维·docker·容器·错误·tar·docker load
初九之潜龙勿用2 小时前
技术与情感交织的一生 (十一)
服务器·笔记·microsoft·印象笔记
明月心9522 小时前
NFS CENTOS系统 安装配置
linux·运维·centos
Raymond运维3 小时前
MySQL 8.0源码编译安装(二)
linux·运维·mysql
xw53 小时前
免费的个人网站托管-InfinityFree
服务器·前端
延凡科技3 小时前
延凡科技光伏清洗预测系统
大数据·运维·人工智能·科技·无人机·智慧城市