Suricata IDS: Unterschied zwischen den Versionen

Aus Xinux Wiki
Zur Navigation springen Zur Suche springen
 
(19 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
==Local Rules==
+
=Debian Template=
*cat  /etc/suricata/rules/local.rules
+
== Vorbereitungen ==
alert icmp any any -> any any (msg:"ICMP Test"; flow:to_server; sid:1;)
+
* VirtualBox Server-Vorlage klonen
alert tcp any any -> any any (flags: S; msg: "SYN packet"; sid:2;)
+
=== Netzkonfiguration IDS (SERVER) ===
 +
{| class="wikitable" style="background-color: #f2f2f2;"
 +
! Parameter !! Wert !! Erläuterung
 +
|-
 +
| '''1. Netzwerk (NIC)''' || SERVER || Management-Interface (SSH, Updates)
 +
|-
 +
| '''IP''' || 10.2XX.1.4 || Statische IP
 +
|-
 +
| '''CIDR''' || 24 || Classless Inter-Domain Routing Präfixlänge
 +
|-
 +
| '''GW''' || 10.2XX.1.1 || GATEWAY
 +
|-
 +
| '''NS''' || 10.88.2XX.21 || Resolver
 +
|-
 +
| '''FQDN''' || suricata-ids.it2XX.int || Fully Qualified Domain Name
 +
|-
 +
| '''SHORT''' || suricata-ids || Short Name
 +
|-
 +
| '''DOM''' || it2XX.int || Domain Name
 +
|-
 +
| '''2. Netzwerk (NIC)''' || DMZ || Sniffing-Interface (Promisc, kein IP) (Modell: virtio)
 +
|-
 +
| '''Promisc Policy''' || allow-all || Pflicht für Mirror-Traffic – nur mit virtio-Modell funktional
 +
|}
 +
;Anpassen des Templates
 +
*[[Anpassen des Debian Templates]]
 +
oder
 +
;Mit Skript
 +
*debian-setup.sh -f suricata-ids.it2XX.int -a 10.2XX.1.4/24 -g 10.2XX.1.1 -n 10.88.2XX.21
  
*https://suricata.readthedocs.io/en/suricata-6.0.0/rules/
+
=Rebooten und einloggen=
 +
*systemctl reboot
  
==Suricata starten==
+
=Anpassen des SNIFF Interfaces=
* Der Systemd Service ist leider verbuggt
+
*Das zweite Interface <code>enp0s8</code> wird als passives Sniffing-Interface konfiguriert – keine IP, kein Gateway, nur Promiscuous Mode.
* manchmal muss die PID File manuell gelöscht werden bevor es starten kann
+
*In VirtualBox zusätzlich den Promiscuous Mode des Adapters auf '''Alle erlauben''' setzen.
* '''rm /var/run/suricata.pid'''
+
<pre>
* Stattdessen diesen Befehl verwenden
+
cat<<HERE >> /etc/network/interfaces
* '''suricata -D --af-packet -c /etc/suricata/suricata.yml'''
+
auto enp0s8
 +
iface enp0s8 inet manual
 +
  post-up ip link set enp0s8 promisc on
 +
HERE
 +
</pre>
 +
*ifup enp0s8
  
== Suricata stoppen ==
+
=Installation=
 +
*apt update
 +
*apt install suricata
  
* Suricata kann über einen UNIX Socket gesteuert werden
+
=Suricata Konfiguration=
* Ein Python-Interface dafür bietet '''suricatasc'''
+
*vim /etc/suricata/suricata.yaml
* '''suricatasc -c shutdown'''
+
<pre>
* '''suricatasc -c reload-rules'''
+
%YAML 1.1
 +
---
 +
vars:
 +
  address-groups:
 +
    LAN: "[172.26.2XX.0/24]"
 +
    DMZ: "[10.88.2XX.0/24]"
 +
    SERVER: "[10.2XX.1.0/24]"
 +
    INT: "[$LAN,$DMZ,$SERVER]"
 +
    HOME_NET: "$INT"
 +
    EXTERNAL_NET: "!$INT"
  
==check==
+
# Sniffing-Interface (Mirror/SPAN Port)
*tail -f /var/log/suricata/fast.log
+
af-packet:
 +
  - interface: enp0s8
 +
    cluster-id: 99
 +
    cluster-type: cluster_flow
 +
    defrag: yes
 +
 
 +
# Standard-Log-Verzeichnis
 +
default-log-dir: /var/log/suricata/
 +
 
 +
# Statistiken
 +
stats:
 +
  enabled: yes
 +
  interval: 8
 +
 
 +
# Ausgaben
 +
outputs:
 +
  - fast:
 +
      enabled: yes
 +
      filename: fast.log
 +
      append: yes
 +
  - eve-log:
 +
      enabled: yes
 +
      filetype: regular
 +
      filename: eve.json
 +
      types:
 +
        - alert
 +
        - http
 +
        - dns
 +
        - tls
 +
        - flow
 +
        - ssh
 +
        - stats
 +
 
 +
# Logging
 +
logging:
 +
  default-log-level: notice
 +
  outputs:
 +
  - console:
 +
      enabled: yes
 +
  - file:
 +
      enabled: yes
 +
      level: info
 +
      filename: suricata.log
 +
 
 +
pid-file: /var/run/suricata.pid
 +
 
 +
unix-command:
 +
  enabled: yes
 +
  filename: /var/run/suricata-command.socket
 +
 
 +
default-rule-path: /etc/suricata/rules
 +
 
 +
rule-files:
 +
  - local.rules
 +
 
 +
classification-file: /etc/suricata/classification.config
 +
reference-config-file: /etc/suricata/reference.config
 +
 
 +
app-layer:
 +
  protocols:
 +
    http:
 +
      enabled: yes
 +
    tls:
 +
      enabled: yes
 +
    smb:
 +
      enabled: yes
 +
    ftp:
 +
      enabled: yes
 +
    ssh:
 +
      enabled: yes
 +
    smtp:
 +
      enabled: yes
 +
    dns:
 +
      enabled: yes
 +
    nfs:
 +
      enabled: yes
 +
    ntp:
 +
      enabled: yes
 +
    krb5:
 +
      enabled: yes
 +
    dhcp:
 +
      enabled: yes
 +
    rdp:
 +
      enabled: yes
 +
    http2:
 +
      enabled: yes
 +
</pre>
 +
 
 +
= Local Rules =
 +
*cat /etc/suricata/rules/local.rules
 +
{{suricata-alert-rules}}
 +
 
 +
=Beschreibung=
 +
{{suricata-rules-beschreibung}}
 +
 
 +
=Suricata als IDS mit systemd starten=
 +
*systemctl enable --now suricata
 +
*tail -fn0 /var/log/suricata/fast.log
 +
 
 +
=Suricata Fernbedienung=
 +
;Reload Rules
 +
*suricatasc -c "reload-rules"
 +
;Shutdown
 +
*suricatasc -c "shutdown"
 +
 
 +
=EveBox=
 +
*[[EveBox]]
 +
 
 +
=Tests=
 +
==ping==
 +
*ping -c 1 1.1.1.1
 +
==DNS Policy==
 +
*host google.de
 +
==Command Injection==
 +
*curl -X POST http://www.it2XX.int/host.php --data-urlencode "fqdn=example.com;ls" -d "submit=Auflösen"
 +
==SQL Injection==
 +
*curl -X POST http://www.it2XX.int/sql-classic.php --data-urlencode "username=' OR '1'='1' --"
 +
==Brute Force SSH==
 +
*wget https://xinux.de/downloads/bad-passwords
 +
*hydra -l kit -P bad-passwords ssh://10.88.2XX.21
 +
==SSH Connection Attempt==
 +
*ssh root@10.88.2XX.21
 +
==HTTP User-Agent Erkennung==
 +
*sqlmap -u "http://www.it2XX.int/sql-classic.php" --data "username=test"
 +
*curl http://www.it2XX.int/host.php
 +
==ICMP Tunnel Erkennung==
 +
*ping -c 5 -s 500 10.88.2XX.21
 +
==DoS==
 +
*ab -n 1000 -c 500 http://www.it2XX.int/
 +
*hping3 -S --flood -V -p 80 10.88.2XX.21
 +
==Nmap Scans==
 +
;SYN-Sweep
 +
*nmap -sS -p1-100 10.88.2XX.21
 +
;UDP-Sweep
 +
*nmap -sU --min-rate=1000 10.88.2XX.21
 +
;Ping-Sweep
 +
*nmap -sn 10.88.2XX.0/24
 +
;NULL-Scan
 +
*nmap -sN -p1-100 10.88.2XX.21
 +
 
 +
= Links =
 +
* https://docs.suricata.io/en/suricata-6.0.0/configuration/suricata-yaml.html#af-packet
 +
* https://docs.suricata.io/en/suricata-6.0.0/capture-hardware/af-packet.html

Aktuelle Version vom 14. Mai 2026, 16:24 Uhr

Debian Template

Vorbereitungen

  • VirtualBox Server-Vorlage klonen

Netzkonfiguration IDS (SERVER)

Parameter Wert Erläuterung
1. Netzwerk (NIC) SERVER Management-Interface (SSH, Updates)
IP 10.2XX.1.4 Statische IP
CIDR 24 Classless Inter-Domain Routing Präfixlänge
GW 10.2XX.1.1 GATEWAY
NS 10.88.2XX.21 Resolver
FQDN suricata-ids.it2XX.int Fully Qualified Domain Name
SHORT suricata-ids Short Name
DOM it2XX.int Domain Name
2. Netzwerk (NIC) DMZ Sniffing-Interface (Promisc, kein IP) (Modell: virtio)
Promisc Policy allow-all Pflicht für Mirror-Traffic – nur mit virtio-Modell funktional
Anpassen des Templates

oder

Mit Skript
  • debian-setup.sh -f suricata-ids.it2XX.int -a 10.2XX.1.4/24 -g 10.2XX.1.1 -n 10.88.2XX.21

Rebooten und einloggen

  • systemctl reboot

Anpassen des SNIFF Interfaces

  • Das zweite Interface enp0s8 wird als passives Sniffing-Interface konfiguriert – keine IP, kein Gateway, nur Promiscuous Mode.
  • In VirtualBox zusätzlich den Promiscuous Mode des Adapters auf Alle erlauben setzen.
cat<<HERE >> /etc/network/interfaces
auto enp0s8
iface enp0s8 inet manual
  post-up ip link set enp0s8 promisc on
HERE
  • ifup enp0s8

Installation

  • apt update
  • apt install suricata

Suricata Konfiguration

  • vim /etc/suricata/suricata.yaml
%YAML 1.1
---
vars:
  address-groups:
    LAN: "[172.26.2XX.0/24]"
    DMZ: "[10.88.2XX.0/24]"
    SERVER: "[10.2XX.1.0/24]"
    INT: "[$LAN,$DMZ,$SERVER]"
    HOME_NET: "$INT"
    EXTERNAL_NET: "!$INT"

# Sniffing-Interface (Mirror/SPAN Port)
af-packet:
  - interface: enp0s8
    cluster-id: 99
    cluster-type: cluster_flow
    defrag: yes

# Standard-Log-Verzeichnis
default-log-dir: /var/log/suricata/

# Statistiken
stats:
  enabled: yes
  interval: 8

# Ausgaben
outputs:
  - fast:
      enabled: yes
      filename: fast.log
      append: yes
  - eve-log:
      enabled: yes
      filetype: regular
      filename: eve.json
      types:
        - alert
        - http
        - dns
        - tls
        - flow
        - ssh
        - stats

# Logging
logging:
  default-log-level: notice
  outputs:
  - console:
      enabled: yes
  - file:
      enabled: yes
      level: info
      filename: suricata.log

pid-file: /var/run/suricata.pid

unix-command:
  enabled: yes
  filename: /var/run/suricata-command.socket

default-rule-path: /etc/suricata/rules

rule-files:
  - local.rules

classification-file: /etc/suricata/classification.config
reference-config-file: /etc/suricata/reference.config

app-layer:
  protocols:
    http:
      enabled: yes
    tls:
      enabled: yes
    smb:
      enabled: yes
    ftp:
      enabled: yes
    ssh:
      enabled: yes
    smtp:
      enabled: yes
    dns:
      enabled: yes
    nfs:
      enabled: yes
    ntp:
      enabled: yes
    krb5:
      enabled: yes
    dhcp:
      enabled: yes
    rdp:
      enabled: yes
    http2:
      enabled: yes

Local Rules

  • cat /etc/suricata/rules/local.rules
# ICMP: einfacher Ping/Traceroute (schneller Funktionstest)
# Test: ping -c 1 1.1.1.1
alert icmp any any -> any any (msg:"ICMP Test"; classtype:misc-activity; sid:9000041;)

# HTTP: mögliches Command-Injection-Merkmal (Semikolon) in POST-Body
# Test: curl -X POST http://www.it2XX.int/host.php --data-urlencode "fqdn=example.com;ls" -d "submit=Auflösen"
alert http any any -> any any (msg:"Command Injection - Semicolon in POST DATA"; classtype:web-application-attack; flow:established; content:"%3B"; nocase; http_client_body; sid:9000002;)

# HTTP: mögliches SQLi-Merkmal (einfaches Hochkomma) in POST-Body
# Test: curl -X POST http://www.it2XX.int/sql-classic.php --data-urlencode "username=' OR '1'='1' --"
alert http any any -> any any (msg:"Possible SQL Injection (singlequote in POST)"; classtype:web-application-attack; flow:established,to_server; content:"%27"; nocase; http_client_body; sid:9000003;)

# DNS: Policy - verbietet "google" in DNS-Queries
# Test: host google.de
alert dns any any -> any any (msg:"Kein Googlen"; dns.query; content:"google"; nocase; classtype:policy-violation; sid:9000043;)

# DoS: viele identische kurze HTTP-GETs (LOIC-ähnlich)
# Test: ab -n 1000 -c 500 http://www.it2XX.int/
alert tcp any any -> any any (msg:"ET DOS Terse HTTP GET Likely LOIC"; flow:to_server,established; dsize:18; content:"GET / HTTP/1.1|0d 0a 0d 0a|"; depth:18; threshold:type both,track by_dst,count 500,seconds 60; classtype:own-dos; sid:9000054; rev:2;)

# Scan: TCP SYN-Sweep (viele SYN in kurzer Zeit)
# Test: nmap -sS -p1-100 10.88.2XX.21
alert tcp any any -> any any (msg:"OWN SCAN TCP SYN sweep"; flow:stateless,to_server; flags:S; detection_filter:track by_src,count 20,seconds 5; classtype:attempted-recon; sid:9000060; rev:1;)

# Scan: TCP NULL-Scan (keine Flags gesetzt)
# Test: nmap -sN -p1-100 10.88.2XX.21
alert tcp any any -> any any (msg:"OWN SCAN TCP NULL scan"; flow:stateless,to_server; flags:0; detection_filter:track by_src,count 5,seconds 10; classtype:attempted-recon; sid:9000061; rev:1;)

# Scan: UDP-Sweep mit leerer Payload
# Test: nmap -sU --min-rate=1000 10.88.2XX.21
alert udp any any -> any any (msg:"OWN SCAN UDP sweep (empty probes)"; flow:to_server; dsize:0; detection_filter:track by_src,count 15,seconds 10; classtype:attempted-recon; sid:9000064; rev:1;)

# Scan: ICMP Ping-Sweep (viele Echo-Requests)
# Test: nmap -sn 10.88.2XX.0/24
alert icmp any any -> any any (msg:"OWN SCAN ICMP ping sweep"; itype:8; detection_filter:track by_src,count 10,seconds 5; classtype:attempted-recon; sid:9000065; rev:1;)

# Brute Force SSH
# Test: hydra -l kit -P bad-passwords ssh://10.88.2XX.21
alert tcp any any -> any 22 (msg:"OWN SSH Brute Force"; flow:to_server,stateless; flags:S; detection_filter:track by_src,count 10,seconds 60; classtype:attempted-recon; sid:9000066; rev:1;)

# HTTP: sqlmap User-Agent erkennen
# Test: sqlmap -u "http://www.it2XX.int/sql-classic.php" --data "username=test"
alert http any any -> any any (msg:"SQLmap Scanner detected"; http.user_agent; content:"sqlmap"; nocase; classtype:web-application-attack; sid:9000070; rev:1;)

# HTTP: curl User-Agent erkennen
# Test: curl http://www.it2XX.int/host.php
alert http any any -> any any (msg:"curl User-Agent detected"; http.user_agent; content:"curl"; nocase; classtype:policy-violation; sid:9000071; rev:1;)

# ICMP Tunnel - großes Payload
# Test: ping -c 5 -s 500 10.88.2XX.21
alert icmp any any -> any any (msg:"OWN ICMP Large Payload - possible tunnel"; itype:8; dsize:>200; classtype:misc-attack; sid:9000072; rev:1;)

# TCP SYN Flood
# Test: hping3 -S --flood -V -p 80 10.88.2XX.21
alert tcp any any -> any any (msg:"TCP SYN Flood Potential Detected"; flags:S; threshold: type both, track by_dst, count 150, seconds 10; classtype:misc-attack; sid:9000073; rev:1;)

# SSH Connection Attempt
# Test: ssh root@10.88.2XX.21
alert tcp any any -> any 22 (msg:"SSH Connection Attempt"; content:"SSH"; nocase; classtype:misc-activity; sid:9000074; rev:1;)

Beschreibung

Schlüsselwort Beschreibung
alert / drop Aktion bei Regelübereinstimmung. alert erzeugt einen Logeintrag, drop verwirft das Paket zusätzlich.
icmp / tcp / udp / http / dns Protokoll das überwacht wird.
any Platzhalter für beliebige IP-Adresse oder Port.
-> Richtung des Datenverkehrs (Quelle → Ziel).
msg:"..." Beschreibung die im Alert-Log erscheint.
classtype:... Kategorie des Angriffs (z.B. web-application-attack, attempted-recon, policy-violation).
sid:... Eindeutige Signatur-ID der Regel. Eigene Regeln beginnen ab 9000000.
flow:... Verbindungsstatus (z.B. established, to_server, stateless).
content:"..." Zeichenkette nach der im Paketinhalt gesucht wird.
nocase Groß-/Kleinschreibung wird beim content-Vergleich ignoriert.
http_client_body Sucht den content nur im HTTP-Request-Body.
http.user_agent Sucht den content im HTTP User-Agent Header.
dns.query Sucht den content im DNS-Query-Namen.
flags:... TCP-Flags (z.B. S=SYN, F=FIN, FPU=XMAS).
itype:... ICMP-Typ (z.B. 8 = Echo Request).
dsize:... Größe der Nutzdaten in Bytes.
detection_filter:... Schwellenwert für Häufigkeit bevor die Regel auslöst.
threshold:... Begrenzung wie oft ein Alert pro Zeitraum ausgelöst wird.
rev:... Revisionsnummer der Regel.

Suricata als IDS mit systemd starten

  • systemctl enable --now suricata
  • tail -fn0 /var/log/suricata/fast.log

Suricata Fernbedienung

Reload Rules
  • suricatasc -c "reload-rules"
Shutdown
  • suricatasc -c "shutdown"

EveBox

Tests

ping

  • ping -c 1 1.1.1.1

DNS Policy

  • host google.de

Command Injection

SQL Injection

Brute Force SSH

SSH Connection Attempt

  • ssh root@10.88.2XX.21

HTTP User-Agent Erkennung

ICMP Tunnel Erkennung

  • ping -c 5 -s 500 10.88.2XX.21

DoS

Nmap Scans

SYN-Sweep
  • nmap -sS -p1-100 10.88.2XX.21
UDP-Sweep
  • nmap -sU --min-rate=1000 10.88.2XX.21
Ping-Sweep
  • nmap -sn 10.88.2XX.0/24
NULL-Scan
  • nmap -sN -p1-100 10.88.2XX.21

Links