abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:55 | IT novinky

    Společnost Valve publikovala přehled To nej roku 2025 ve službě Steam aneb ohlédnutí za nejprodávanějšími, nejhranějšími a dalšími nej hrami roku 2025.

    Ladislav Hagara | Komentářů: 0
    dnes 16:11 | Komunita

    Byly publikovány výsledky průzkumu mezi uživateli Blenderu uskutečněného v říjnu a listopadu 2025. Zúčastnilo se více než 5000 uživatelů.

    Ladislav Hagara | Komentářů: 0
    dnes 03:33 | Bezpečnostní upozornění

    V dokumentově orientované databázi MongoDB byla nalezena a v upstreamu již opravena kritická bezpečností chyba CVE-2025-14847 aneb MongoBleed.

    Ladislav Hagara | Komentářů: 0
    včera 23:11 | IT novinky

    Při úklidu na Utažské univerzitě se ve skladovacích prostorách náhodou podařilo nalézt magnetickou pásku s kopií Unixu V4. Páska byla zaslána do počítačového muzea, kde se z pásky úspěšně podařilo extrahovat data a Unix spustit. Je to patrně jediný známý dochovaný exemplář tohoto 52 let starého Unixu, prvního vůbec programovaného v jazyce C.

    🇨🇽 | Komentářů: 1
    včera 15:55 | Komunita

    FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.

    🇨🇽 | Komentářů: 7
    včera 15:44 | Zajímavý software

    K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.

    🇨🇽 | Komentářů: 1
    včera 15:33 | Zajímavý software

    Yazi je správce souborů běžící v terminálu. Napsán je v programovacím jazyce Rust. Podporuje asynchronní I/O operace. Vydán byl v nové verzi 25.12.29. Instalovat jej lze také ze Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    26.12. 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    26.12. 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 7
    26.12. 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (33%)
     (1%)
     (23%)
     (1%)
     (2%)
     (1%)
     (11%)
     (11%)
     (17%)
    Celkem 195 hlasů
     Komentářů: 21, poslední dnes 18:58
    Rozcestník

    Dotaz: Policy based routing pro WireGuard tunel s VPS

    27.12.2023 15:24 Deryl | skóre: 11
    Policy based routing pro WireGuard tunel s VPS
    Přečteno: 472×

    Dobré odpoledne,

    TLDR; Nedaří se mi směrovat packety s "odpovědí" zpět do wireguard tunelu.

    O co jde

    Mám
    - VPS v cloudu s veřejnou IP adresou s nastavenou MASQUERADE na `wan0` pro odchozí komunikaci do internetu.
    - server 10.11.13.21 v lokální síti (gw 10.11.13.1).

    Cílem je:
    - zpřístupnit služby na LAN serveru do internetu.
    - aby služby na LAN serveru viděly _skutečnou src address_ klienta z internetu.
    - aby komunikace počínající (state NEW) na LAN serveru byla směrována standardně přes CGNAT a nikoliv wg tunelem přes VPSku (omezená bandwith, cena).

    Nestačí mi:
    - Webová reverse proxy na VPSce.
    - Protože ta neřeší přístup na ostatní služby (IMAP, SMTP, cokoliv nepoužívající HTTP...)

    Vyzkoušel jsem, funguje to, ale nesplňuje to podmínky:
    - WireGuard mezi VPS a LAN serverm s pomocí DNAT (směrování portů z veřejné IP na LAN server) a AllowedIPs=0.0.0.0/0: skript `wg-quick` automaticky změní default route a veškerá komunikace jde přes tunel.
    - `rathole` mezi VPSkou a LAN serverem - službám se dotazy jeví jako od `localhost`.

    Marně zkouším:
    - Vypnout automatiku `wg-quick` ohledně směrování.
    - Označit komunikaci přicházející na LAN server z `wg0` (tunelu).
    - Stejně označit i odpovědi služeb v rámci související komunikace.
    - Nastavit policy based routing, aby označené pakety použily jako default route ten tunel a tedy zbylá komunikace nešla přes tunel, ale CGNAT (lokální router a ISP).

    Dotaz z internetu přes VPS dorazí na lokální server, ale odpověď se vratí přes lokální router a ISP, takže je nakonec "zahozen". Nicméně, ping mezi VPSkou a LAN serverem funguje.

    Konkrétně:

    /etc/wireguard/wg0.conf na LAN serveru:

    [Interface]
    Address = 10.0.37.2/24
    ... zkráceno ...
    Table = off  
    PostUp = iptables -t mangle -A PREROUTING -i wg0 -j CONNMARK --set-mark 0x51872  
    PostUp = iptables -t mangle -A OUTPUT -m mark --mark 0x51872 -j CONNMARK --restore-mark  
    PostUp = ip route add default dev wg0 table 51872  
    PostUp = ip rule add fwmark 0x51872 table 51872  
    [Peer]
    ...
    AllowedIPs = 10.0.37.1/32,0.0.0.0/0


    Stav na LAN serveru:

    # ip rule show all  
    0:      from all lookup local  
    32765:  from all fwmark 0x51872 lookup 51872  
    32766:  from all lookup main  
    32767:  from all lookup default
    # ip route show table all
    default dev wg0 table 51872 scope link
    default via 10.11.13.1 dev br1 proto static
    10.0.37.0/24 dev wg0 proto kernel scope link src 10.0.37.2
    10.11.13.0/24 dev br1 proto kernel scope link src 10.11.13.21
    172.17.0.0/24 dev docker0 proto kernel scope link src 172.17.0.1 linkdown
    ... zkráceno ...
    local 10.0.37.2 dev wg0 table local proto kernel scope host src 10.0.37.2
    broadcast 10.0.37.255 dev wg0 table local proto kernel scope link src 10.0.37.2


    Co dělám špatně. Případně: jak to vyřešit jinak?



    Řešení dotazu:


    Odpovědi

    27.12.2023 17:38 Deryl | skóre: 11
    Rozbalit Rozbalit vše Re: Policy based routing pro WireGuard tunel s VPS

    Ještě k tomu doplním tcpdump na LAN serveru, když z jiného počítače mimo LAN zkouším `ssh -p22 user@moje.vps.net`.

    # tcpdump -i wg0 port 22
    14:45:39.649749 IP 37-188-184-76.red.o2.cz.46002 > 10.11.13.21.ssh: Flags [S], seq 1788730745, win 65535, options [mss 1420,sackOK,TS val 260893484 ecr0,nop,wscale 9], length 0
    # tcpdump -i br1 port 22 | grep -i 'o2.cz'
    14:45:39.649823 IP 10.11.13.21.ssh > 37-188-184-76.red.o2.cz.46002: Flags [S.], seq 1539991552, ack 1788730746, win 65160, options [mss 1460,sackOK,TS val 863901811 ecr 260893484,nop,wscale 7], length 0

    kde `wg0` je tunel a `br1` je LAN. Dotaz jde tunelem, odpověď odchází do LAN...

    Řešení 1× (Deryl (tazatel))
    27.12.2023 22:20 Deryl | skóre: 11
    Rozbalit Rozbalit vše Re: Policy based routing pro WireGuard tunel s VPS

    Vyřešeno, hloupá chyba.

    Bylo:

    PostUp = iptables -t mangle -A OUTPUT -m mark --mark 0x51872 -j CONNMARK --restore-mark

    Mělo být:

    PostUp = iptables -t mangle -I OUTPUT -m connmark --mark 0x51872 -j CONNMARK --restore-mark

    V chainu OUTPUT nejsou označeny pakety, pouze spojení. Takže filtr měl být na `connmark` a nikoliv `mark`.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.