0

0

Linux 安全:如何配置 mod_evasive 防止 DoS / DDoS 攻击

冰川箭仙

冰川箭仙

发布时间:2025-11-21 18:54:09

|

801人浏览过

|

来源于php中文网

原创

mod_evasive通过监控请求频率防御DoS攻击,安装后配置DOSPageCount、DOSSiteCount等参数控制访问阈值,设置DOSBlockingPeriod封锁超限IP,结合DOSWhitelist避免误封,日志记录至/var/log/httpd,可选DOSBlockingExec联动iptables封禁,需合理配置防止误判,适用于抵御小规模CC攻击。

linux 安全:如何配置 mod_evasive 防止 dos / ddos 攻击

mod_evasive 是 Apache 的一个模块,用于帮助防止 DoS(拒绝服务)和 DDoS(分布式拒绝服务)攻击。它通过监控客户端请求频率,在检测到异常行为时自动阻止 IP 地址,从而减轻服务器负载并保护网站可用性。以下是配置 mod_evasive 的具体步骤。

安装 mod_evasive 模块

在大多数 Linux 发行版中,mod_evasive 不是默认启用的,需要手动安装。

  • CentOS / RHEL / Rocky Linux:使用 EPEL 仓库安装

yum install -y epel-release
yum install -y mod_evasive

  • Ubuntu / Debian:通过 apt 安装

apt update
apt install -y libapache2-mod-evasive

安装完成后,Apache 会自动加载该模块,无需手动添加 LoadModule 指令(通常已包含在配置中)。

配置 mod_evasive 参数

配置文件位置因系统而异:

  • Ubuntu/Debian: /etc/apache2/mods-available/evasive.conf
  • CentOS/RHEL: /etc/httpd/conf.d/mod_evasive.conf

编辑配置文件,设置以下关键参数:


    # 每个客户端每秒最多请求次数(同一子目录)
    DOSPageInterval 1
    DOSPageCount 2
# 每个客户端每秒最多总请求数
DOSSiteInterval 1
DOSSiteCount 50

# 黑名单持续时间(秒)
DOSBlockingPeriod 600

# 记录日志路径
DOSLogDir "/var/log/httpd"

# 触发拦截时执行的命令(可选:发送警报或防火墙封禁)
# DOSBlockingExec "iptables -I INPUT -s %s -j DROP"

# 白名单 IP(避免误封内部网络)
DOSWhitelist 127.0.0.1
DOSWhitelist 192.168.1.*

说明:

  • DOSPageCount 表示单个页面每秒最多请求次数,超过则触发拦截
  • DOSSiteCount 控制整个站点每秒最大请求数
  • DOSBlockingPeriod 决定 IP 被封锁的时间长度
  • DOSWhitelist 可防止本地或可信 IP 被误封

设置日志与监控

确保日志目录存在且 Apache 有写入权限:

易标AI
易标AI

告别低效手工,迎接AI标书新时代!3分钟智能生成,行业唯一具备查重功能,自动避雷废标项

下载

mkdir -p /var/log/httpd
chown apache:apache /var/log/httpd chown www-data:www-data /var/log/httpd

查看拦截记录:

tail -f /var/log/httpd/mod_evasive.log

日志内容示例:

[client 203.0.113.45] Blacklisted for exceeding request limits

集成防火墙增强防护(可选)

可通过 DOSBlockingExec 自动调用 iptables 封禁恶意 IP:

DOSBlockingExec "sudo /sbin/iptables -I INPUT -s %s -j DROP"

注意:需确保 Apache 用户(如 www-data 或 apache)有免密码执行 iptables 的权限:

visudo
添加:
www-data ALL=(ALL) NOPASSWD: /sbin/iptables

重启 Apache 生效配置:

systemctl restart httpd
systemctl restart apache2

基本上就这些。mod_evasive 不能完全替代专业 DDoS 防护服务,但对于小规模 CC 攻击或暴力扫描非常有效。合理设置阈值,避免误伤正常用户,同时结合 fail2ban、CDN 和防火墙规则,能显著提升 Web 服务器安全性。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

325

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

231

2023.10.07

apache是什么意思
apache是什么意思

Apache是Apache HTTP Server的简称,是一个开源的Web服务器软件。是目前全球使用最广泛的Web服务器软件之一,由Apache软件基金会开发和维护,Apache具有稳定、安全和高性能的特点,得益于其成熟的开发和广泛的应用实践,被广泛用于托管网站、搭建Web应用程序、构建Web服务和代理等场景。本专题为大家提供了Apache相关的各种文章、以及下载和课程,希望对各位有所帮助。

405

2023.08.23

apache启动失败
apache启动失败

Apache启动失败可能有多种原因。需要检查日志文件、检查配置文件等等。想了解更多apache启动的相关内容,可以阅读本专题下面的文章。

930

2024.01.16

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1348

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

701

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号