Linux 安装 fail2ban

Linux 安装 fail2ban

fail2ban是一款入侵防御软件,能够运行在大多数Linux服务器上,保护计算机服务器免受暴力破解的攻击。fail2ban启动后会通过检测系统行为日志识别暴力破解行为,对于在短时间内多次未能通过身份验证的请求,fail2ban会自动调用系统自带的防火墙或包管理框架(如iptables或tcp wrapper等)进行封禁。

作者:炭烤毛蛋 ,点击博主了解更多。


提示:安装fail2ban之前,建议将ssh服务配置为通过密钥登录并禁止密码登录。

文章目录

  • Linux 安装 fail2ban
  • 1. 安装 fail2ban
  • 2. fail2ban 配置
    • 2.1 IP访问白名单
    • 2.2 IP访问黑名单
  • 3. 启动 fail2ban 失败情况分析
    • 3.1 fail2ban 加载服务运行参数与系统不匹配
  • 3.2 fail2ban 加载服务启动参数错误
  • 结语


1. 安装 fail2ban

安装 fail2ban

sudo apt install fail2ban

启动 fail2ban 服务并设置开机自启

# 启动 fail2ban
sudo systemctl start fail2ban
# 设置 fail2ban 开机自启
sudo systemctl enable fail2ban

2. fail2ban 配置

安装后默认生成配置文件。更新Fail2ban时它们可能会被覆盖配置文件,不建议直接修改。

/etc/fail2ban/jail.d/defaults-debian.conf
/etc/fail2ban/jail.conf

按顺序读取配置文件,.conf 优先读取,但.local文件会覆盖 .conf 文件。

/etc/fail2ban/jail.conf
/etc/fail2ban/jail.d/*.conf
/etc/fail2ban/jail.d/*.conf
/etc/fail2ban/jail.d/*.local

2.1 IP访问白名单

不会从这些IP检测是否是恶意的访问,额外增加jail.local覆写jail.conf。

sudo cp /etc/fail2ban/jail.{conf,local}
sudo vi /etc/fail2ban/jail.local
# 增加忽略访问 IP
[DEFAULT]
ignoreip = 127.0.0.1/8 ::1 192.168.1.0/24
findtime = 60
maxretry = 5
bantime = -1
banaction = iptables-allports[ssh]
enable = true
port = 22
filter = sshd
logpath = /var/log/auth.log

[DEFAULT] 属性介绍:
ignoreip是忽略访问禁止IP。通常会设置回环地址和网关地址。
bantime,findtime和maxretry选项的值定义了禁止时间和禁止条件。

bantime是禁止持续的时间。如果未指定后缀,则默认为秒。默认情况下,bantime值设置为10分钟。通常,大多数用户都希望设置更长的禁止时间。你也可以根据您的喜好更改值bantime的值,要永久禁止IP,请使用负数:
bantime = 2d

findtime是设置失败次数之间的持续时间。 例如,如果将Fail2ban设置为在尝试五次失败后禁止IP(请参见下文maxretry),则这些失败必须在findtime时间内发生,即10分钟完成5次失败的尝试。
findtime = 10m

maxretry是允许IP失败尝试次数。 默认值设置为5,对于大多数用户来说应该够用。
maxretry = 5

banaction是端口禁止条件,iptables-allports 是禁用所有端口。

[ssh] 配置条件介绍
enable = true 是启用 ssh 扫描判断
port = 22 ssh的端口,如 ssh 更换默认端口,需要修改为相应端口
fileter = sshd 启用sshd 扫描判断
logpath 日志存放是路径

2.2 IP访问黑名单

邮件通知 IP 禁用
Fail2ban可以在IP被禁止时发送电子邮件警报。 要接收电子邮件,您需要在服务器上安装SMTP并更改默认的action,该action操作仅将IP禁止为%(action_mw)s

action = %(action_mw)s

(action_mw)s将禁止有问题的IP,并发送包含Whois报告的电子邮件。 如果要在电子邮件中包含相关日志,请将操作设置为%(action_mwl)s。可以调整发送和接收电子邮件地址:
destemail = admin@myfreax.com
sender = root@myfreax.com

Fail2ban Jail
Fail2ban使用Jail的概念,jail直接翻译就是囚牢。 Jail描述如何检测服务的条件。其中服务是系统的任意服务,比如sshd服务,Vsftpd服务等。条件是包括过滤器和操作。计算符合搜索模式的日志记录,并在满足预定条件时执行相应的操作。
Fail2ban附带许多Jail作为示例,系统每一项服务都可以找到对应Jail配置。 您还可以创建自己的Jail配置。默认情况下,在CentOS 8上没有启用Jail。 要启用Jail,您需要在添加enabled = true。 以下示例显示了如何为sshd服务启用Jail:

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

重新启动Fail2ban服务,以使更改生效:

sudo systemctl restart fail2ban

查看 sshd 服务状态

sudo fail2ban-client status sshd

解除IP限制

sudo fail2ban-client set sshd unbanip 23.45.67.89

锁定限制 IP

sudo fail2ban-client set sshd banip 23.45.67.89

查看禁用 IP 脚本

#!/bin/bash
bad_ip=` grep 'Failed password for root from' /var/log/secure|awk '{print $11,$1,$2}'|sort|uniq -c|awk '$1>4 {print $2}'|xargs`for ip in $bad_ip; doin_iptables=`iptables -nvL|grep $ip |wc -l`if [ $in_iptables -eq 0 ]; theniptables -I INPUT -s $ip -j REJECTservice iptables savefi
done

3. 启动 fail2ban 失败情况分析

3.1 fail2ban 加载服务运行参数与系统不匹配

fail2ban [5639]: ERROR Failed during configuration: File contains no section headers.

原因:系统不支持systemctl,需要改为systemd启动。
解决方法:

[DEFAULT]
backend = systemd
Failed during configuration: Have not found any log file for sshd jail.

原因:应该是fail2ban默认开启ssh监控,却找不到ssh的日志。
解决方法同上。

3.2 fail2ban 加载服务启动参数错误

ExecStart=/usr/bin/fail2ban-server -xf start (code=exited, status=255/EXCEPTION)
running fail2ban-client -x start and you will get something descriptive.fail2ban-client -x start
2024-03-26 09:33:05,641 fail2ban [10289]: ERROR Failed during configuration: While reading from '/etc/fail2ban/jail.local' [line 133]: option 'backend' in section 'DEFAULT' already exists

根据系统提示找到,backend参数,将原有 backend = auto 改为 systemd 启动正常。

结语

不枉博主详细讲解,欢迎订阅博主–炭烤毛蛋 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/788940.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PAC下的ROP问题

Armv8.3-A引入了pointer authentication选项。 pointer authentication可以减轻ROP攻击。 为了防止ROP攻击,在函数开始时,LR寄存器中的返回地址被签名。这意味着在寄存器的高位添加了一个PAC。在返回之前,使用PAC对返回地址进行验证。如果检查…

国外服务器租用需要考虑哪些重要信息

国外服务器租用是指从国外的数据中心或服务提供商那里租用服务器资源,以便部署网站、应用程序或其他网络服务。那么国外服务器租用需要考虑哪些重要信息,rak小编为您整理发布。 以下是一些关于国外服务器租用的重要信息: 1. 选择服务商:有许多…

搜索二维矩阵 II - LeetCode 热题 21

大家好!我是曾续缘💗 今天是《LeetCode 热题 100》系列 发车第 21 天 矩阵第 4 题 ❤️点赞 👍 收藏 ⭐再看,养成习惯 搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性&…

Word的”交叉引用“和”插入题注“快捷键设置

Word的”交叉引用“和”插入题注“快捷键设置 在MSWord2021中,可以自定义设置快捷键。方法如下:文件-选项-自定义功能区-键盘快捷方式(自定义)。具体过程如图所示。 最后,按照上述流程将插入题注(Insert…

详解 Proxychains4 和 Tor 命令行网络代理的配置及使用方法

使用 tor 保护自己 前置 要求 kali linux 系统开启全局科学上网 安装Proxychains4 并配置 安装 Proxychains4 apt-get install Proxychains4 # 或者 apt install Proxychains4 编辑 配置文件 ┌──(root㉿kali)-[~] └─# whereis proxychains proxychains: /usr/bin/pro…

VMware vCenter Server 8.0U2c - 集中式管理 vSphere 环境

VMware vCenter Server 8.0U2c - 集中式管理 vSphere 环境 请访问原文链接:https://sysin.org/blog/vmware-vcenter-8-u2/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 无耻抄袭者 Yu Tao,请立遁&…

3D模型格式转换工具HOOPS Exchange如何将3D文件加载到PRC数据结构中?

HOOPS Exchange是一款高效的数据访问工具,专为开发人员设计,用于在不同的CAD(计算机辅助设计)系统之间进行高保真的数据转换和交换。由Tech Soft 3D公司开发,它支持广泛的CAD文件格式,包括但不限于AutoCAD的…

分享高质量嵌入式软件的开发技巧

大家好,今天给大家介绍分享高质量嵌入式软件的开发技巧,文章末尾附有分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!可进群免费领取。 高质量嵌入式软件的开发技巧涉及多个方面,从设计、…

python -- NotOpenSSLWarning: urllib3 v2 only supports OpenSSL 1.1.1+

报错分析 完整的报错:urllib3 v2 only supports OpenSSL 1.1.1, currently the ssl module is compiled with LibreSSL 2.8.3. See: https://github.com/urllib3/urllib3/issues/3020报错分析:LibreSSL 是 OpenSSL 的一个分支,LibreSSL 2.8.…

Java基础语法(十)| 多态

1. 多态 1.1 什么是多态 多态是继封装、继承之后,面向对象的第三大特性。生活中,比如跑的动作,小猫、小狗和大象,都是动物,跑起来是不一样的。 再比如飞的动作,昆虫、鸟类和飞机,飞起来也是不一样的。 可见…

不同设备使用同一个Git账号

想要在公司和家里的电脑上用同一个git账号来pull, push代码 1. 查看原设备的用户名和邮箱 第1种方法, 依次输入 git config user.name git config user.email第2种方法, 输入 cat ~/.gitconfig2. 配置新设备的用户名和邮箱 用户名和邮箱与原设备保持…

rocketmq管理工具rocketmq-console安装

rocketmq-console是一个图形化管理控制台,提供Broker集群状态查看,Topic管理,Producer、Consumer状态展示,消息查询等常用功能,这个功能在安装好RocketMQ后需要额外单独安装、运行。 中文文档地址:https:/…

【RedHat9.0】引导装载程序GRUB——root密码丢失实例

root用户密码忘记了?!!!怎么办!!! 在Linux系统中,root密码是系统管理员权限的凭证。 如果忘记了root密码,就无法以管理员身份登录系统,这可能会对系统安全和正…

C++核心高级编程 --- 1、内存分区模型 2、引用

文章目录 第一章:1.内存分区模型1.1 程序运行前1.2 程序运行后1.3 new操作符 第二章:2.引用2.1 使用2.2 注意事项2.3 做函数参数2.4 做函数返回值2.5 本质2.6 常量引用 第一章: 1.内存分区模型 4个区域: 代码区:存放…

Python可视化概率统计和聚类学习分析生物指纹

🎯要点 🎯使用Jupyter Notebook执行Dash 应用,确定Dash输入输出,设计回调函数,Dash应用中包含函数。🎯使用Plotly绘图工具:配置图对象选项,​将图转换为HTML、图像。使用数据集绘图…

健身房最重的是前门

你可以将任何你想做的事情 比如 一年读30本书 变成一周读一页 做四天瑜伽 变成拿出瑜伽垫 我知道真正的目的不只是拿出瑜伽垫 我知道我其实是想锻炼身体 这只是某种心理上的把戏 虽然暂时不会得到想要的结果 但退一步往远看 其实是在掌握“持续出现”的习惯 这让我们…

【mysql 第3-10条记录怎么查】

mysql 第3-10条记录怎么查 在MySQL中,如果你想要查询第3到第10条记录,你通常会使用LIMIT和OFFSET子句。但是,需要注意的是,LIMIT和OFFSET是基于结果集的行数来工作的,而不是基于记录的物理位置。这意味着它们通常与某种…

【C++庖丁解牛】高阶数据结构---红黑树详解(万字超详细全面介绍红黑树)

🍁你好,我是 RO-BERRY 📗 致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 🎄感谢你的陪伴与支持 ,故事既有了开头,就要画上一个完美的句号,让我们一起加油 目录 前言1.红黑树的概念2.红黑…

vue + vite 项目架构笔记---- PC端屏幕自适应方案

背景: 项目中总有很多界面 需要做大小屏幕适配的兼容,那么怎么能够快速实现这一方案呢,SASS的出现是个非常好用的工具,可以通过自定义函数,来实现自动计算。 方案:vue3 vite sass 具体实现细节&#x…

开发环境搭建及驱动移植 2

1 开发环境搭建 前言: STD库-标准外设库 寄存器操作,将一些基本的寄存器操作封装成函数 HAL库-硬件抽象库将这些抽象成了一个抽象层,从使用的角度来看,是与硬件无关的 HAL库优势HAL库是ST未来主推的库,从2015开始ST…