百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

使用 Fail Ban 日志分析 SSH 攻击行为

yuyutoo 2025-04-30 21:00 10 浏览 0 评论

通过分析 `fail2ban` 日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:

---

### **一、Fail2ban 日志位置**

Fail2ban的日志路径因系统配置而异,常见位置包括:

```bash

/var/log/fail2ban.log # 主日志文件

/var/log/fail2ban.log.1 # 归档日志(如已轮转)

journalctl -u fail2ban -f # 通过systemd查看实时日志(Linux)

```

---

### **二、关键日志分析场景**

#### **1. 识别高频攻击IP**

通过统计被Ban的IP及其频率:

```bash

sudo grep "Ban " /var/log/fail2ban.log | awk '{print $NF}' | sort | uniq -c | sort -n

```

输出示例:

```

12 45.33.18.119

23 185.142.239.16

```

- **解读**:IP `185.142.239.16` 被Ban了23次,可能是持续攻击源。

#### **2. 分析攻击时间规律**

提取攻击发生的时间段:

```bash

sudo grep "Ban " /var/log/fail2ban.log | awk '{print $1,$2}' | uniq -c

```

输出示例:

```

5 2024-01-01 03:00

8 2024-01-01 06:00

```

- **解读**:攻击集中在凌晨时段,可针对性加强监控。

#### **3. 检查攻击手法**

查看触发Ban的SSH失败日志(需结合`/var/log/auth.log`):

```bash

sudo grep "Failed password" /var/log/auth.log | grep "from=<被Ban的IP>"

```

输出示例:

```

Jan 1 03:00:01 sshd[1234]: Failed password for root from 45.33.18.119 port 22 ssh2

Jan 1 03:00:03 sshd[1235]: Failed password for root from 45.33.18.119 port 22 ssh2

```

- **解读**:攻击者针对`root`账户进行暴力破解。

#### **4. 确认封禁有效性**

检查IP是否被正确加入防火墙规则:

```bash

sudo iptables -L -n | grep 45.33.18.119 # Linux

sudo fail2ban-client status sshd # 查看当前被封禁的IP

```

---

### **三、高级分析工具**

#### **1. 使用 `fail2ban-client` 实时监控**

```bash

sudo fail2ban-client status sshd # 查看sshd监狱状态

sudo fail2ban-client get sshd banip # 列出所有被封禁IP

```

#### **2. 可视化分析(ELK Stack)**

将日志导入Elasticsearch + Kibana,生成可视化报表:

- 攻击IP地理分布

- 攻击频率趋势图

#### **3. 自定义日志分析脚本**

统计TOP 10攻击IP及其尝试次数:

```bash

sudo awk '/Failed password/{print $11}' /var/log/auth.log | sort | uniq -c | sort -nr | head -10

```

---

### **四、安全加固建议**

#### **1. 调整Fail2ban配置**

编辑 `/etc/fail2ban/jail.local`:

```ini

[sshd]

enabled = true

maxretry = 3 # 3次失败后封禁

bantime = 1d # 封禁1天(默认10分钟)

findtime = 1h # 1小时内触发规则

ignoreip = 192.168.1.0/24 # 忽略内网IP

```

#### **2. 替换默认SSH端口**

修改 `/etc/ssh/sshd_config`:

```ini

Port 2222 # 改用非标准端口

PermitRootLogin no # 禁止root直接登录

PasswordAuthentication no # 强制使用密钥认证

```

重启SSH服务:

```bash

sudo systemctl restart sshd

```

#### **3. 联动防火墙增强防护**

自动封禁攻击IP到防火墙(示例配置):

```ini

[sshd]

banaction = iptables-multiport

banaction_allports = iptables-allports # 封禁所有端口

```

#### **4. 启用多因素认证(MFA)**

- 使用Google Authenticator或TOTP增强SSH登录安全。

---

### **五、自动化响应脚本**

自动提取攻击IP并添加到防火墙黑名单:

```bash

#!/bin/bash

# 提取过去1小时被Ban的IP并永久封禁

grep "$(date -d '1 hour ago' +'%Y-%m-%d %H')" /var/log/fail2ban.log | grep "Ban " | awk '{print $NF}' | while read IP; do

iptables -A INPUT -s $IP -j DROP

echo "[$(date)] Banned $IP permanently" >> /var/log/ip_blacklist.log

done

```

---

### **六、总结流程图**

```

收集日志 → 分析高频IP → 确认攻击手法 → 调整封禁策略 → 加固SSH配置 → 自动化防御

```

通过持续监控和分析Fail2ban日志,可以显著提升服务器对抗SSH暴力破解的能力。对于高价值目标,建议结合网络层防火墙(如Cloudflare)和入侵检测系统(OSSEC)形成多层防御。

相关推荐

《保卫萝卜2》安卓版大更新 壕礼助阵世界杯

《保卫萝卜2:极地冒险》本周不仅迎来了安卓版本的重大更新,同时将于7月4日本周五,带来“保卫萝卜2”安卓版本世界杯主题活动的火热开启,游戏更新与活动两不误。一定有玩家会问,激萌塔防到底进行了哪些更新?...

儿童手工折纸:胡萝卜,和孩子一起边玩边学carrot

1、准备两张正方形纸,一橙一绿,对折出折痕。2、橙色沿其中一条对角线如图折两三角形。3、把上面三角折平,如图。4、绿色纸折成三角形。5、再折成更小的三角形。6、再折三分之一如图。7、打开折纸,压平中间...

《饥荒》食物代码有哪些(饥荒最新版代码总汇食物篇)

饥荒游戏中,玩家们需要获取各种素材与食物,进行生存。玩家们在游戏中,进入游戏后按“~”键调出控制台使用代码,可以直接获得素材。比如胡萝卜的代码是carrot,玉米的代码是corn,南瓜的代码是pump...

Skyscanner:帮你找到最便宜机票 订票不求人

你喜欢旅行吗?在合适的时间、合适的目的地,来一场说走就走的旅行?机票就是关键!Skyscanner这款免费的手机应用,在几秒钟内比较全球600多家航空公司的航班安排、价格和时刻表,帮你节省金钱和时间。...

小猪佩奇第二季50(小猪佩奇第二季英文版免费观看)

Sleepover过夜Itisnighttime.现在是晚上。...

我在民政局工作的那些事儿(二)(我在民政局上班)

时间到了1997年的秋天,经过一年多的学习和实践,我在处理结婚和离婚的事情更加的娴熟,也获得了领导的器重,所以我在处理平时的工作时也能得心应手。这一天我正在离婚处和同事闲聊,因为离婚处几天也遇不到人,...

夏天来了就你还没瘦?教你不节食13天瘦10斤的哥本哈根减肥法……

好看的人都关注江苏气象啦夏天很快就要来了你是否和苏苏一样身上的肉肉还没做好准备?真是一个悲伤的故事……下面这个哥本哈根减肥法苏苏的同事亲测有效不节食不运动不反弹大家快来一起试试看吧~DAY1...

Pursuing global modernization for peaceful development, mutually beneficial cooperation, prosperity for all

AlocalworkeroperatesequipmentintheChina-EgyptTEDASuezEconomicandTradeCooperationZonei...

Centuries-old tea road regains glory as Belt and Road cooperation deepens

FUZHOU/ST.PETERSBURG,Oct.2(Xinhua)--NestledinthepicturesqueWuyiMountainsinsoutheastChi...

15 THE NUTCRACKERS OF NUTCRACKER LODGE (CONTINUED)胡桃夹子小屋里的胡桃夹子(续篇)

...

AI模型部署:Triton Inference Server模型部署框架简介和快速实践

关键词:...

Ftrace function graph简介(flat function)

引言由于android开发的需要与systrace的普及,现在大家在进行性能与功耗分析时候,经常会用到systrace跟pefetto.而systrace就是基于内核的eventtracing来实...

JAVA历史版本(java各版本)

JAVA发展1.1996年1月23日JDK1.0Java虚拟机SunClassicVM,Applet,AWT2.1997年2月19日JDK1.1JAR文件格式,JDBC,JavaBea...

java 进化史1(java的进阶之路)

java从1996年1月第一个版本诞生,到2022年3月最新的java18,已经经历了27年,整整18个大的版本。很久之前有人就说java要被淘汰,但是java活到现在依然坚挺,不知道java还能活...

学习java第二天(java学完后能做什么)

#java知识#...

取消回复欢迎 发表评论: