data:image/s3,"s3://crabby-images/da923/da923d1758474c24a699a39a72275ed1736d5f18" alt="Debian"
Unter Stretch rate ich dazu,
data:image/s3,"s3://crabby-images/da923/da923d1758474c24a699a39a72275ed1736d5f18" alt="Debian"
data:image/s3,"s3://crabby-images/da923/da923d1758474c24a699a39a72275ed1736d5f18" alt="Debian"
Also jetzt der Reihe nach:
Code: Alles auswählen
apt install -t stretch-backports nftables
...
5 aktualisiert, 3 neu installiert, 0 zu entfernen
Meine simple Version für einen Desktop-PC mit Erklärungen zu den jeweiligen Rules:
/etc/nftables.conf:
Code: Alles auswählen
#!/usr/sbin/nft -f
# /etc/nftables.conf
flush ruleset
table inet filter {
chain input {
type filter hook input priority 0;
# accept any localhost traffic
iif lo accept
# accept traffic originated from us
ct state established,related accept
ct state invalid counter drop
# allow ping (echo request) at limited rate. 2nd rule needed to handle established.
ip6 nexthdr icmpv6 icmpv6 type echo-request limit rate 10/second accept
ip6 nexthdr icmpv6 icmpv6 type echo-request counter log prefix "nft-ping_flood " drop
ip protocol icmp icmp type echo-request limit rate 10/second accept/etc/nftables.conf
ip protocol icmp icmp type echo-request counter log prefix "nft-ping_flood " drop
# IPv6: accept ICMP for neighbour discovery, otherwise IPv6 connectivity breaks.
ip6 nexthdr icmpv6 icmpv6 type { nd-neighbor-solicit, nd-router-advert, nd-neighbor-advert } accept
# IPv6: ICMP redirects (type 137) is included in "ct stat invalid"
# ip6 nexthdr icmpv6 icmpv6 type nd-redirect counter drop
# IPv4: accept & count all other ICMP.
ip protocol icmp icmp type { destination-unreachable, router-solicitation, router-advertisement, time-exceeded, parameter-problem } counter accept
# IPv4: drop & count IGMP (Multicast) i.e. FritzBox for IPTV, unused by me.
ip protocol igmp counter drop
# accept common local services: SSH, CUPS
tcp dport { 22, 631 } ct state new accept
# FritzBox scans for ports 80 und 14013: unused by me
tcp dport { 80, 14013 } ct state new counter drop
# broadcast from this PC: AVAHI and CUPS
udp dport { 5353, 161 } counter drop
# broadcast from this PC: saned searching scanners
udp dport { 1124, 3289, 8610, 8612 } counter drop
# NetBIOS, SMB von b3, Win10 WM, laptops
udp dport { 137, 138 } counter drop
# broadcast from other clients for DHCP
udp dport { 67 } counter drop
# drop any other traffic, count and log to nftables.log.
counter log prefix "nft-final_drop " drop
}
# Forwarding is not requiered on a desktop PC
# chain forward {
# type filter hook forward priority 0;
# }
chain output {
type filter hook output priority 0;
}
}
Fürs Logging in einem eigenen Logfile statt des "syslog" folgende Konfigurationsdatei erstellen:
/etc/rsyslog.d/01_nft_log.conf:
Code: Alles auswählen
# /etc/rsyslog.d/01_nft_log.conf
# Log for nftables if activated. Prevent writing to syslog by "& stop"
#
# prefix nft-* : where "*" indicates a specific rule in nftables.conf.
#
:msg,regex,"nft." -/var/log/nftables.log
& stop
Checken, ob bereits iptables aktiv ist (beides, d.h. iptables und nftables gleichzeitig wird nicht empfohlen):
Code: Alles auswählen
iptables -L
Code: Alles auswählen
systemctl restart rsyslog.service
systemctl (re)start|reload nftables.service
systemctl enable nftables.service
SSH-Zugang
Drucker/CUPS von anderen PCs aus.
Meine Konfiguration ist jetzt soweit, dass ich alle normalerweise einfach durchs letzte "drop" verworfenen UDP-Pakete den entsprechenden Anwendungen zuordnen konnte - deshalb die Aufteilung auf mehrere Regeln. Kann dann auch jeder bei Bedarf separat auf "accept" setzen. Damit bleibt im Normalfall das Log leer, nur unerlaubte Zugriffsversuche werden geloggt.
Ich stelle die ganze Konfiguration zur Diskussion und bin über weitere Anregungen/Verbesserungen dankbar. Eine ergiebige Quelle für Information ist das Projekt-Wiki https://wiki.nftables.org/wiki-nftables ... 10_minutes und auch die Wikis von Arch und Gentoo.
EDIT/Nachtrag, nur zur Info:
a) Anzeige des gesamten Filters mit Anzahl der gefilterten Pakete, bei denen "counter" gesetzt ist:
Als root:
Code: Alles auswählen
nft list ruleset
data:image/s3,"s3://crabby-images/da923/da923d1758474c24a699a39a72275ed1736d5f18" alt="Debian"
c)
data:image/s3,"s3://crabby-images/da923/da923d1758474c24a699a39a72275ed1736d5f18" alt="Debian"
d) Sehr comfortabel: Einträge in der table "inet" gelten gleich für beides, IPv4 und IPv6!