Linux下如何安装配置Fail2ban防护工具

简介: 通过以上步骤,可以在Linux系统中成功安装和配置Fail2ban,从而有效保护服务器免受暴力破解等攻击。Fail2ban通过实时监控日志文件,自动更新防火墙规则,为系统安全提供了一层重要的保护。

Linux下安装配置Fail2ban防护工具

Fail2ban是一款开源的入侵防护工具,通过监控日志文件来检测潜在的攻击行为,如暴力破解,并自动更新防火墙规则以阻止这些攻击。本文将详细介绍如何在Linux系统中安装和配置Fail2ban。

一、安装Fail2ban

1. 安装Fail2ban

在Debian/Ubuntu系统中,可以使用以下命令安装Fail2ban:

sudo apt update
sudo apt install fail2ban
​

在CentOS/RHEL系统中,可以使用以下命令安装Fail2ban:

sudo yum install epel-release
sudo yum install fail2ban
​

2. 启动和启用Fail2ban服务

安装完成后,启动Fail2ban服务并设置为开机自启动:

sudo systemctl start fail2ban
sudo systemctl enable fail2ban
​

3. 检查Fail2ban服务状态

可以使用以下命令检查Fail2ban服务的状态:

sudo systemctl status fail2ban
​

二、配置Fail2ban

1. 创建本地配置文件

Fail2ban的默认配置文件位于 /etc/fail2ban/jail.conf,不建议直接修改该文件。相反,我们可以创建一个本地配置文件 /etc/fail2ban/jail.local 来覆盖默认设置。

sudo cp /etc/fail2ban/jail.conf /etc/fail2ban/jail.local
​

2. 配置基本设置

打开并编辑 /etc/fail2ban/jail.local 文件:

sudo nano /etc/fail2ban/jail.local
​

[DEFAULT] 部分,可以配置全局设置,例如:

[DEFAULT]
bantime  = 3600     # 被禁止的时间长度(秒)
findtime = 600      # 在该时间段内进行检测(秒)
maxretry = 5        # 失败尝试次数
​

3. 启用并配置具体服务

jail.local 文件中,配置具体服务的设置,例如SSH服务:

[sshd]
enabled = true
port    = ssh
logpath = %(sshd_log)s
backend = %(sshd_backend)s
​

确保将 enabled 设置为 true,以启用对SSH服务的保护。

三、Fail2ban 过滤器配置

Fail2ban 通过过滤器(filters)来解析日志文件中的失败尝试记录,并采取相应的措施。

1. 查看默认过滤器

Fail2ban的默认过滤器文件位于 /etc/fail2ban/filter.d/ 目录中。例如,SSH的过滤器文件是 sshd.conf

2. 自定义过滤器

如果需要创建自定义过滤器,可以在 /etc/fail2ban/filter.d/ 目录中创建新的过滤器文件,例如 custom.conf

sudo nano /etc/fail2ban/filter.d/custom.conf
​

在文件中定义过滤规则,例如:

[Definition]
failregex = <HOST> - - [.*] "GET /wp-login.php HTTP/1.1" 200
​

四、测试Fail2ban配置

1. 测试配置文件语法

可以使用以下命令测试Fail2ban的配置文件语法:

sudo fail2ban-client -d
​

2. 手动测试过滤器

可以使用以下命令手动测试过滤器的匹配情况:

sudo fail2ban-regex /var/log/auth.log /etc/fail2ban/filter.d/sshd.conf
​

五、管理Fail2ban

1. 查看被禁IP列表

使用以下命令查看当前被禁的IP列表:

sudo fail2ban-client status sshd
​

2. 手动解禁IP

使用以下命令手动解禁某个IP:

sudo fail2ban-client set sshd unbanip <IP_ADDRESS>
​

3. 重启Fail2ban服务

每次修改配置后,需要重启Fail2ban服务以使更改生效:

sudo systemctl restart fail2ban
​

六、总结

通过以上步骤,可以在Linux系统中成功安装和配置Fail2ban,从而有效保护服务器免受暴力破解等攻击。Fail2ban通过实时监控日志文件,自动更新防火墙规则,为系统安全提供了一层重要的保护。

思维导图

目录
相关文章
|
4月前
|
Linux 开发工具
7种比较Linux中文本文件的最佳工具
7种比较Linux中文本文件的最佳工具
7种比较Linux中文本文件的最佳工具
|
2月前
|
Linux 数据安全/隐私保护 iOS开发
推荐Linux环境下效能优良的双向文件同步工具
综合上述条件,对于Linux环境下的双向文件同步需求,Unison 和 Syncthing 是两个非常出色的选择。它们都有良好的社区支持和文档资源,适用于不同规模的环境,从个人使用到商业部署。Unison 特别适合那些需要手动干预同步过程、需要处理文件冲突解决的场景。而 Syncthing 更加现代化,适合需要自动、实时的数据同步与备份的环境。对于选择哪一个,这将取决于个人的使用场景和具体需求。
261 16
|
4月前
|
Ubuntu 搜索推荐 Linux
详解Ubuntu的strings与grep命令:Linux开发的实用工具。
这就是Ubuntu中的strings和grep命令,透明且强大。我希望你喜欢这个神奇的世界,并能在你的Linux开发旅程上,通过它们找到你的方向。记住,你的电脑是你的舞台,在上面你可以做任何你想做的事,只要你敢于尝试。
264 32
|
2月前
|
存储 安全 Linux
Linux服务器上安装配置GitLab的步骤。
按照以上步骤,一个基础的GitLab服务应该运行并可以使用。记得定期检查GitLab官方文档,因为GitLab的安装和配置步骤可能随着新版本而变化。
219 0
|
6月前
|
自然语言处理 数据库 iOS开发
DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具
DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具
418 12
DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具
|
5月前
|
运维 安全 Linux
试试Linux设备命令行运维工具——Wowkey
WowKey 是一款专为 Linux 设备设计的命令行运维工具,提供自动化、批量化、标准化、简单化的运维解决方案。它简单易用、高效集成且无依赖,仅需 WIS 指令剧本文件、APT 账号密码文件和 wowkey 命令即可操作。通过分离鉴权内容与执行内容,WowKey 让运维人员专注于决策,摆脱繁琐的交互与执行细节工作,大幅提升运维效率与质量。无论是健康检查、数据采集还是配置更新,WowKey 都能助您轻松应对大规模设备运维挑战。立即从官方资源了解更多信息:https://atsight.top/training。
|
5月前
|
数据采集 运维 安全
Linux设备命令行运维工具WowKey问答
WowKey 是一款用于 Linux 设备运维的工具,可通过命令行手动或自动执行指令剧本,实现批量、标准化操作,如健康检查、数据采集、配置更新等。它简单易用,只需编写 WIS 指令剧本和 APT 帐号密码表文件,学习成本极低。支持不同流派的 Linux 系统,如 RHEL、Debian、SUSE 等,只要使用通用 Shell 命令即可通吃Linux设备。
|
7月前
|
Linux API
Linux下载工具wget与curl
`wget` 是一个用于从网络下载文件的命令行工具,支持HTTP、HTTPS和FTP协议。它能自动处理下载中断,并支持递归下载网站内容。基本用法:`wget URL`,可指定文件名(`-O`)、保存目录(`-P`),还支持断点续传(`-c`)、限速(`--limit-rate`)和递归下载(`-r`)。相比之下,`curl` 更侧重于发送各种HTTP请求(如GET、POST),并支持文件上传、自定义请求头和cookie等功能。
181 10
|
7月前
|
存储 Ubuntu 前端开发
Linux软件包管理工具概览
在Linux系统中,dpkg、apt、rpm、yum和dnf是几种常见的包管理工具,它们分别属于不同的Linux发行版或家族,并有着各自的诞生顺序和特点。下面将按照这些工具的诞生顺序,并结合Debian、Red Hat、CentOS、Ubuntu和Kali等系统,进行详细的介绍。
172 4