0

0

Linux防护工具使用教程_fail2baniptables防暴力破解

舞夢輝影

舞夢輝影

发布时间:2026-01-03 18:38:57

|

669人浏览过

|

来源于php中文网

原创

fail2ban是日志驱动的入侵响应工具,通过分析auth.log等日志识别SSH等服务的暴力破解行为,触发iptables封禁IP;配置启用[sshd]、调优maxretry/bantime/findtime后重启即可生效。

linux防护工具使用教程_fail2baniptables防暴力破解

fail2ban 是 Linux 系统中防范 SSH、FTP、Web 登录等服务暴力破解最常用且有效的工具,它通过实时分析日志(如 /var/log/auth.log),自动识别异常登录尝试,并调用 iptables(或 nftables)封禁攻击者 IP。配置得当,能显著降低被撞库、爆破的风险。

fail2ban 的核心工作逻辑

fail2ban 不是防火墙本身,而是一个“日志驱动的入侵响应守护进程”:

  • 持续监控指定服务的日志文件(例如 SSH 的失败登录记录)
  • 按预设规则(filter)匹配“失败行为”,比如连续 5 次密码错误
  • 达到阈值后,调用 jail 配置中的 action(默认为 iptables 封禁)加入临时黑名单
  • 封禁时长由 bantime 控制,可设为永久(-1)或若干秒(如 3600 表示 1 小时)

快速部署 fail2ban(以 Ubuntu/Debian 为例)

安装与基础启用只需几步:

Robovision AI
Robovision AI

一个强大的视觉AI管理平台

下载
  • 执行 sudo apt update && sudo apt install fail2ban
  • 复制默认配置为本地可编辑版本:sudo cp /etc/fail2ban/jail.conf /etc/fail2ban/jail.local
  • 编辑 jail.local,确保 [sshd] 段启用:enabled = true
  • 可调整关键参数(在 [sshd] 下):
    maxretry = 3(3 次失败即触发)
    bantime = 7200(封禁 2 小时)
    findtime = 600(10 分钟内累计达 maxretry 才封)
  • 重启服务:sudo systemctl restart fail2ban

验证是否生效 & 常用管理命令

部署后别急着离开,立即检查状态和日志:

  • 查看整体状态:sudo fail2ban-client status
  • 查看 SSH 监控详情:sudo fail2ban-client status sshd(会显示当前封禁 IP 数及列表)
  • 手动解封某个 IP:sudo fail2ban-client set sshd unbanip 192.168.1.100
  • 查看实时日志(调试用):sudo tail -f /var/log/fail2ban.log
  • 确认 iptables 规则已插入:sudo iptables -L INPUT -n | grep f2b-(应看到类似 f2b-sshd 的自定义链)

进阶建议:提升防护鲁棒性

基础配置够用,但生产环境建议补充以下实践:

  • 禁用密码登录,改用密钥认证:从源头杜绝暴力破解可能,PermitRootLogin noPasswordAuthentication no 写入 /etc/ssh/sshd_config 后重载 sudo systemctl reload sshd
  • 限制 SSH 访问来源(白名单优先):在 iptables 或云平台安全组中,只放行可信 IP 段访问 22 端口
  • 启用 recidive jail(防反复攻击):对多次被封的 IP 加长封禁时间,需在 jail.local 中启用 [recidive] 并设置 bantime = 604800(7 天)
  • 日志轮转配合:确保 logrotate 正常工作,避免 fail2ban 因日志切分丢失上下文;检查 /etc/logrotate.d/fail2ban

相关专题

更多
点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.24

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

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

1345

2023.06.21

如何安装LINUX
如何安装LINUX

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

700

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修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

773

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

545

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

296

2023.07.20

python设置中文版教程合集
python设置中文版教程合集

本专题整合了python改成中文版相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.05

热门下载

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

精品课程

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

共48课时 | 6.6万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

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

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