Crowdsec SSH Bruteforce Beispiel: Unterschied zwischen den Versionen

Aus Xinux Wiki
Zur Navigation springen Zur Suche springen
 
(8 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
==Wichtig==
+
= CrowdSec – SSH Brute-Force Erkennung =
;Vorraussetzung Crowdsec ist installiert  
+
 
;Im Labor empfielt es sich die Whitelist zu bearbeiten.
+
== Voraussetzung ==
*vi /etc/crowdsec/parsers/s02-enrich/whitelists.yaml
+
; CrowdSec ist installiert und die Whitelist ist angepasst.
name: crowdsecurity/whitelists
 
description: "Whitelist events from private ipv4 addresses"
 
whitelist:
 
  reason: "private ipv4/ipv6 ip/ranges"
 
  ip:
 
    - "::1"
 
    - "192.168.178.1"
 
  cidr:
 
    # - "127.0.0.0/8"
 
    # - "192.168.0.0/16"
 
    # - "10.0.0.0/8"
 
    # - "172.16.0.0/12"
 
# expression:
 
    #  - "'foo.com' in evt.Meta.source_ip.reverse"
 
*systemctl restart crowdsec
 
  
 
== Installation der SSH-Collection ==
 
== Installation der SSH-Collection ==
* sudo cscli collections install crowdsecurity/sshd
+
Installiert alle Parser und Szenarien für SSH-Brute-Force-Erkennung.
* sudo systemctl reload crowdsec
+
* cscli collections install crowdsecurity/sshd
 +
* systemctl reload crowdsec
  
 
== Installation des nftables Bouncers ==
 
== Installation des nftables Bouncers ==
; Wenn noch nicht geschehen
+
Der Bouncer setzt erkannte Angriffe in nftables-Regeln um und blockt die Angreifer-IP.
 
* apt install crowdsec-firewall-bouncer-nftables
 
* apt install crowdsec-firewall-bouncer-nftables
  
== Neustart des Bouncers ==
+
== Bouncer neu starten und prüfen ==
* sudo systemctl restart crowdsec-firewall-bouncer
+
Nach der Installation wird der Bouncer gestartet und der Status geprüft.
* sudo systemctl status crowdsec-firewall-bouncer
+
* systemctl restart crowdsec-firewall-bouncer
 +
* systemctl status crowdsec-firewall-bouncer
  
== Überprüfen, ob der Bouncer mit CrowdSec verbunden ist ==
+
== Bouncer-Verbindung zu CrowdSec prüfen ==
* sudo cscli bouncers list
+
Zeigt ob der Bouncer korrekt bei der Engine registriert ist.
 +
* cscli bouncers list
  
== Überprüfung der installierten SSH-Szenarien ==
+
== Installierte SSH-Szenarien prüfen ==
* sudo cscli scenarios list | grep ssh
+
Filtert die Szenarienliste auf SSH-relevante Einträge.
 +
* cscli scenarios list | grep ssh
  
== Auf dem Attacker starten wir nun einen Angriff ==
+
== Angriff vom Attacker durchführen ==
; Passwortliste besorgen
+
 
 +
=== Passwortliste herunterladen ===
 
* wget https://xinux.de/downloads/bad-passwords
 
* wget https://xinux.de/downloads/bad-passwords
; Hydra installieren
+
 
 +
=== Hydra installieren ===
 +
* apt update
 
* apt install hydra -y
 
* apt install hydra -y
; Attacke
 
* hydra -l root -P bad-passwords ssh://10.0.10.132 -V
 
  
== Die IP sollte hier erscheinen ==
+
=== Angriff starten ===
* ipset list  crowdsec-blacklists-1
+
Hydra führt einen SSH-Brute-Force-Angriff gegen das Ziel durch.
 +
* hydra -l christine -P bad-passwords ssh://10.88.2XX.11 -V
  
Name: crowdsec-blacklists-1
+
== Erkannte Angriffe anzeigen ==
Type: hash:net
+
Listet alle von CrowdSec erkannten und protokollierten Alerts auf.
Revision: 7
+
* cscli alerts list
Header: family inet hashsize 1024 maxelem 131072 timeout 300 bucketsize 12 initval 0xadaaeb46
 
Size in memory: 520
 
References: 1
 
Number of entries: 1
 
Members:
 
192.168.178.102 timeout 14298
 
==Alle böse IPs==
 
* ipset list  crowdsec-blacklists-0
 
 
 
== Überprüfung der erkannten SSH-Angriffe ==
 
* sudo cscli alerts list
 
  
 
<pre>
 
<pre>
+----+-------------------+---------------------------+---------+----+-----------+-----------------------------------------+
+
+----+----------------------+---------------------------+---------+----+-----------+-----------------------------------------+
| ID |       value       |          reason          | country | as | decisions |              created_at                |
+
| ID |       value         |          reason          | country | as | decisions |              created_at                |
+----+-------------------+---------------------------+---------+----+-----------+-----------------------------------------+
+
+----+----------------------+---------------------------+---------+----+-----------+-----------------------------------------+
| 3  | Ip:10.0.10.99    | crowdsecurity/ssh-slow-bf |        |    | ban:1    | 2025-03-08 10:07:24.268224992 +0000 UTC |
+
| 3  | Ip:172.26.2XX.100    | crowdsecurity/ssh-slow-bf |        |    | ban:1    | 2025-03-08 10:07:24.268224992 +0000 UTC |
| 2  | Ip:10.0.10.99    | crowdsecurity/ssh-bf      |        |    | ban:1    | 2025-03-08 10:07:24.268879637 +0000 UTC |
+
| 2  | Ip:172.26.2XX.100    | crowdsecurity/ssh-bf      |        |    | ban:1    | 2025-03-08 10:07:24.268879637 +0000 UTC |
+----+-------------------+---------------------------+---------+----+-----------+-----------------------------------------+
+
+----+----------------------+---------------------------+---------+----+-----------+-----------------------------------------+
 
</pre>
 
</pre>
  
== Anzeige der gebannten IP-Adressen ==
+
== Gebannte IP-Adressen anzeigen ==
* sudo cscli decisions list
+
Zeigt alle aktiven Sperrentscheidungen der Engine an.
 +
* cscli decisions list
  
 
<pre>
 
<pre>
╭───────┬──────────┬───────────────┬───────────────────────────┬────────┬─────────┬────┬────────┬────────────────────┬──────────╮
+
╭───────┬──────────┬────────────────────┬───────────────────────────┬────────┬─────────┬────┬────────┬────────────────────┬──────────╮
│  ID  │  Source  │ Scope:Value │          Reason          │ Action │ Country │ AS │ Events │    expiration    │ Alert ID │
+
│  ID  │  Source  │   Scope:Value     │          Reason          │ Action │ Country │ AS │ Events │    expiration    │ Alert ID │
├───────┼──────────┼───────────────┼───────────────────────────┼────────┼─────────┼────┼────────┼────────────────────┼──────────┤
+
├───────┼──────────┼────────────────────┼───────────────────────────┼────────┼─────────┼────┼────────┼────────────────────┼──────────┤
│ 15002 │ crowdsec │ Ip:10.0.10.99 │ crowdsecurity/ssh-slow-bf │ ban    │        │    │ 13    │ 3h58m41.750831936s │ 3        │
+
│ 15002 │ crowdsec │ Ip:172.26.2XX.100  │ crowdsecurity/ssh-slow-bf │ ban    │        │    │ 13    │ 3h58m41.750831936s │ 3        │
╰───────┴──────────┴───────────────┴───────────────────────────┴────────┴─────────┴────┴────────┴────────────────────┴──────────╯
+
╰───────┴──────────┴────────────────────┴───────────────────────────┴────────┴─────────┴────┴────────┴────────────────────┴──────────╯
1 duplicated entries skipped
 
 
</pre>
 
</pre>
  
== Live-Log der CrowdSec-Analyse anzeigen ==
+
== Ban aufheben ==
* sudo journalctl -u crowdsec -f
+
Entfernt den Ban für eine bestimmte IP-Adresse manuell.
 +
* cscli decisions delete --ip 172.26.2XX.100
 +
 
 +
== Live-Log der CrowdSec-Analyse ==
 +
Zeigt die laufende Analyse von CrowdSec in Echtzeit.
 +
* journalctl -u crowdsec -f
  
== Überprüfung der installierten Parser, Szenarien und Bouncer ==
+
== Installierte Komponenten prüfen ==
* sudo cscli parsers list
+
Gibt einen Überblick über alle aktiven Parser, Szenarien und Bouncer.
* sudo cscli scenarios list
+
* cscli parsers list
* sudo cscli bouncers list
+
* cscli scenarios list
 +
* cscli bouncers list
  
== Test: Anzeige der letzten SSH-Fehlversuche ==
+
== Letzte SSH-Fehlversuche anzeigen ==
* sudo journalctl -u ssh -g "Failed password" --no-pager | tail -n 20
+
Filtert das Systemjournal nach fehlgeschlagenen SSH-Anmeldeversuchen.
 +
* journalctl -u ssh -g "Failed password" --no-pager | tail -n 20

Aktuelle Version vom 24. Mai 2026, 09:01 Uhr

CrowdSec – SSH Brute-Force Erkennung

Voraussetzung

CrowdSec ist installiert und die Whitelist ist angepasst.

Installation der SSH-Collection

Installiert alle Parser und Szenarien für SSH-Brute-Force-Erkennung.

  • cscli collections install crowdsecurity/sshd
  • systemctl reload crowdsec

Installation des nftables Bouncers

Der Bouncer setzt erkannte Angriffe in nftables-Regeln um und blockt die Angreifer-IP.

  • apt install crowdsec-firewall-bouncer-nftables

Bouncer neu starten und prüfen

Nach der Installation wird der Bouncer gestartet und der Status geprüft.

  • systemctl restart crowdsec-firewall-bouncer
  • systemctl status crowdsec-firewall-bouncer

Bouncer-Verbindung zu CrowdSec prüfen

Zeigt ob der Bouncer korrekt bei der Engine registriert ist.

  • cscli bouncers list

Installierte SSH-Szenarien prüfen

Filtert die Szenarienliste auf SSH-relevante Einträge.

  • cscli scenarios list | grep ssh

Angriff vom Attacker durchführen

Passwortliste herunterladen

Hydra installieren

  • apt update
  • apt install hydra -y

Angriff starten

Hydra führt einen SSH-Brute-Force-Angriff gegen das Ziel durch.

Erkannte Angriffe anzeigen

Listet alle von CrowdSec erkannten und protokollierten Alerts auf.

  • cscli alerts list
+----+----------------------+---------------------------+---------+----+-----------+-----------------------------------------+
| ID |        value         |          reason           | country | as | decisions |               created_at                |
+----+----------------------+---------------------------+---------+----+-----------+-----------------------------------------+
| 3  | Ip:172.26.2XX.100    | crowdsecurity/ssh-slow-bf |         |    | ban:1     | 2025-03-08 10:07:24.268224992 +0000 UTC |
| 2  | Ip:172.26.2XX.100    | crowdsecurity/ssh-bf      |         |    | ban:1     | 2025-03-08 10:07:24.268879637 +0000 UTC |
+----+----------------------+---------------------------+---------+----+-----------+-----------------------------------------+

Gebannte IP-Adressen anzeigen

Zeigt alle aktiven Sperrentscheidungen der Engine an.

  • cscli decisions list
╭───────┬──────────┬────────────────────┬───────────────────────────┬────────┬─────────┬────┬────────┬────────────────────┬──────────╮
│  ID   │  Source  │    Scope:Value     │          Reason           │ Action │ Country │ AS │ Events │     expiration     │ Alert ID │
├───────┼──────────┼────────────────────┼───────────────────────────┼────────┼─────────┼────┼────────┼────────────────────┼──────────┤
│ 15002 │ crowdsec │ Ip:172.26.2XX.100  │ crowdsecurity/ssh-slow-bf │ ban    │         │    │ 13     │ 3h58m41.750831936s │ 3        │
╰───────┴──────────┴────────────────────┴───────────────────────────┴────────┴─────────┴────┴────────┴────────────────────┴──────────╯

Ban aufheben

Entfernt den Ban für eine bestimmte IP-Adresse manuell.

  • cscli decisions delete --ip 172.26.2XX.100

Live-Log der CrowdSec-Analyse

Zeigt die laufende Analyse von CrowdSec in Echtzeit.

  • journalctl -u crowdsec -f

Installierte Komponenten prüfen

Gibt einen Überblick über alle aktiven Parser, Szenarien und Bouncer.

  • cscli parsers list
  • cscli scenarios list
  • cscli bouncers list

Letzte SSH-Fehlversuche anzeigen

Filtert das Systemjournal nach fehlgeschlagenen SSH-Anmeldeversuchen.

  • journalctl -u ssh -g "Failed password" --no-pager | tail -n 20