<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki.ixheim.de/index.php?action=history&amp;feed=atom&amp;title=Nftables_Erweiterungen</id>
	<title>Nftables Erweiterungen - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.ixheim.de/index.php?action=history&amp;feed=atom&amp;title=Nftables_Erweiterungen"/>
	<link rel="alternate" type="text/html" href="https://wiki.ixheim.de/index.php?title=Nftables_Erweiterungen&amp;action=history"/>
	<updated>2026-06-29T00:02:41Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Xinux Wiki</subtitle>
	<generator>MediaWiki 1.35.1</generator>
	<entry>
		<id>https://wiki.ixheim.de/index.php?title=Nftables_Erweiterungen&amp;diff=61590&amp;oldid=prev</id>
		<title>Thomas.will: Die Seite wurde neu angelegt: „= Erweiterte Funktionen in nftables =  == ipsec-policy ==  * nftables kann prüfen, ob ein Paket durch IPsec gesichert ist. * Die Prüfung erfolgt mit dem Ausd…“</title>
		<link rel="alternate" type="text/html" href="https://wiki.ixheim.de/index.php?title=Nftables_Erweiterungen&amp;diff=61590&amp;oldid=prev"/>
		<updated>2025-04-12T20:49:27Z</updated>

		<summary type="html">&lt;p&gt;Die Seite wurde neu angelegt: „= Erweiterte Funktionen in nftables =  == ipsec-policy ==  * nftables kann prüfen, ob ein Paket durch IPsec gesichert ist. * Die Prüfung erfolgt mit dem Ausd…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;= Erweiterte Funktionen in nftables =&lt;br /&gt;
&lt;br /&gt;
== ipsec-policy ==&lt;br /&gt;
&lt;br /&gt;
* nftables kann prüfen, ob ein Paket durch IPsec gesichert ist.&lt;br /&gt;
* Die Prüfung erfolgt mit dem Ausdruck ''ipsec in'' bzw. ''ipsec out''.&lt;br /&gt;
* Beispiele:&lt;br /&gt;
** '''ipsec in reqid 1 accept'''&lt;br /&gt;
** '''ipsec in spi 0x12345678 drop'''&lt;br /&gt;
&lt;br /&gt;
== policy-routing ==&lt;br /&gt;
&lt;br /&gt;
* Routing-Entscheidungen können mit ''meta mark'' oder ''fib'' beeinflusst werden.&lt;br /&gt;
* Beispielsweise für differenziertes Routing je nach Paketmarkierung.&lt;br /&gt;
* Beispiele:&lt;br /&gt;
** '''meta mark set 0x10'''&lt;br /&gt;
** '''fib daddr type local accept'''&lt;br /&gt;
&lt;br /&gt;
== mss-reduction ==&lt;br /&gt;
&lt;br /&gt;
* Um Probleme mit MTU und TCP über VPNs zu vermeiden, kann die MSS angepasst werden.&lt;br /&gt;
* Dies wird mit dem tcp option parser in nftables realisiert.&lt;br /&gt;
* Beispiel:&lt;br /&gt;
** '''tcp flags syn tcp option maxseg size set 1300'''&lt;br /&gt;
&lt;br /&gt;
= Portforwarding mit sauberer Kontrolle =&lt;br /&gt;
&lt;br /&gt;
* Bei klassischem Portforwarding wird nur nach der DNAT-Umsetzung geprüft.&lt;br /&gt;
* Wenn man bereits den ursprünglichen Verbindungsaufbau zur öffentlichen Adresse prüfen will, muss vor DNAT markiert werden.&lt;br /&gt;
&lt;br /&gt;
== nftables-Beispiel für sauberes Portforwarding ==&lt;br /&gt;
&lt;br /&gt;
'''vim /etc/nftables.conf'''&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#!/usr/sbin/nft -f&lt;br /&gt;
&lt;br /&gt;
flush ruleset&lt;br /&gt;
&lt;br /&gt;
define wanif = ens18&lt;br /&gt;
define lanif = ens20&lt;br /&gt;
define wanip = 10.82.232.11&lt;br /&gt;
define webserver = 192.168.4.12&lt;br /&gt;
&lt;br /&gt;
table inet mangle {&lt;br /&gt;
  chain prerouting {&lt;br /&gt;
    type filter hook prerouting priority mangle; policy accept;&lt;br /&gt;
    iifname $wanif ip daddr $wanip tcp dport 80 mark set 0x8&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
table ip nat {&lt;br /&gt;
  chain prerouting {&lt;br /&gt;
    type nat hook prerouting priority dstnat; policy accept;&lt;br /&gt;
    iifname $wanif ip daddr $wanip tcp dport 80 dnat to $webserver:80&lt;br /&gt;
  }&lt;br /&gt;
&lt;br /&gt;
  chain postrouting {&lt;br /&gt;
    type nat hook postrouting priority srcnat; policy accept;&lt;br /&gt;
    oifname $wanif ip saddr 192.168.4.0/24 snat to $wanip&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
table inet filter {&lt;br /&gt;
  chain forward {&lt;br /&gt;
    type filter hook forward priority filter; policy drop;&lt;br /&gt;
    ct state established,related accept&lt;br /&gt;
    mark 0x8 accept&lt;br /&gt;
    # Optional: Übergabe an Suricata&lt;br /&gt;
    # mark 0x8 queue num 0&lt;br /&gt;
    log prefix &amp;quot;--nftables-drop-forward--&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
&lt;br /&gt;
  chain input {&lt;br /&gt;
    type filter hook input priority filter; policy drop;&lt;br /&gt;
    iif &amp;quot;lo&amp;quot; accept&lt;br /&gt;
    ct state established,related accept&lt;br /&gt;
    log prefix &amp;quot;--nftables-drop-input--&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
&lt;br /&gt;
  chain output {&lt;br /&gt;
    type filter hook output priority filter; policy drop;&lt;br /&gt;
    ct state established,related accept&lt;br /&gt;
    log prefix &amp;quot;--nftables-drop-output--&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Weiterleitung an eine Queue (z. B. Suricata) ==&lt;br /&gt;
&lt;br /&gt;
* Statt ''accept'' in der FORWARD-Kette kann auch eine Queue verwendet werden:&lt;br /&gt;
&lt;br /&gt;
'''mark 0x8 queue num 0'''&lt;br /&gt;
&lt;br /&gt;
* Suricata muss mit '''--nfqueue''' und Queue-Nummer 0 gestartet werden.&lt;br /&gt;
* Beispiel-Aufruf:&lt;br /&gt;
&lt;br /&gt;
'''suricata -c /etc/suricata/suricata.yaml -q 0'''&lt;/div&gt;</summary>
		<author><name>Thomas.will</name></author>
	</entry>
</feed>