वायरगार्ड सर्वर और क्लाइंट एक दूसरे को पिंग करने में सक्षम हैं, लेकिन वायरगार्ड क्लाइंट एक दूसरे को पिंग करने में असमर्थ हैं

Aug 18 2020

मैं एक वायरगार्ड कॉन्फ़िगरेशन स्थापित कर रहा हूं जहां मेरे पास निम्नलिखित इकाइयां हैं:

  1. दूरस्थ VM उदाहरण पर होस्ट करता है जैसे कि Google क्लाउड या अमेज़ॅन aws। यह मेरे वायरगार्ड सर्वर का रिमोट क्लाइंट है। इसको बुलाते हैंgcp_client

  2. मेरे LAN पर होस्ट की गई मशीन पर वायरगार्ड सर्वर। चलो यह कहते हैं srvlan

  • इस उपकरण पर IPv4 अग्रेषण सक्षम है sysctl
  • WAN और मेरे LAN के बीच एक Ubiquiti Edgerouter 4 है। मैंने इस डिवाइस पर पोर्ट फ़ॉरवर्डिंग और हेयरपिन NAT को सक्षम किया है। मैंने इस राउटर पर एक गतिशील डीएनएस भी स्थापित किया है।
  1. मेरे LAN पर एक या अधिक क्लाइंट, जो रिमोट क्लाइंट से कनेक्ट करने में सक्षम होना चाहिए जैसे कि यह मेरे LAN पर एक मशीन था। जैसा कि मैं अपने पहले ग्राहक के साथ समस्या का सामना कर रहा हूं, चलो इसे कॉल करें client1

मेरे सेटअप में, मैं srvlanऔर gcp_clientदोनों तरीकों के बीच, और बीच में client1और srvlanसाथ ही साथ पिंग करने में सक्षम हूं । तथापि। से पिंग gcp_clientकरने के लिए client1(और इसके विपरीत) असफल।

के परिणामों को पढ़ने के आधार पर tcpdump -i wg0 -n icmp, मैंने निम्नलिखित अवलोकन किए:

  1. से पिंग client1करने के लिए gcp_clientतक पहुँचने srvlanलेकिन रूटर अग्रेषित नहीं कर रहे हैं।
  2. मेरे राउटर तक पहुंचने के gcp_clientलिए पिंग client1, जो उन्हें आगे की ओर srvlan। हालांकि पैकेट द्वारा अग्रेषित नहीं मिलता srvlanके लिए client1

इससे मैं केवल यही निष्कर्ष निकाल सकता हूं कि आगे के नियम srvlanकिसी तरह दोषपूर्ण हैं। मैं nftablesइस उपकरण का प्रबंधन करने के लिए उपयोग कर रहा हूं ।

यह मेरा वायरगार्ड कॉन्फ़िगरेशन है; आईपी ​​पते और पोर्ट नंबर को बदल दिया गया है।

# wg0.conf for gcp_client
[Interface]
Address = 10.0.1.2/24
ListenPort = 50000
PrivateKey = gcp_client_privkey

[Peer]
PublicKey = srvlan_pubkey
AllowedIPs = 10.0.1.0/24
Endpoint = srvlan_ddns:50000

# wg0.conf for srvlan
[Interface]
Address = 10.0.1.1/24
ListenPort = 50000
PrivateKey = srvlan_privkey

[Peer]
PublicKey = gcp_client_pubkey
AllowedIPs = 10.0.1.2/32
Endpoint = gcp_client_domainname:50000
PersistentKeepalive = 25

[Peer]
PublicKey = client1_pubkey
AllowedIPs = 10.0.1.3/32
Endpoint = client1_lanhostname:50000
PersistentKeepalive = 25 # I realise this one is unnecessary, but I had added it while testing just in case the problem got fixed.

# wg0.conf for client1
[Interface]
Address = 10.0.1.3/24
ListenPort = 50000
PrivateKey = client1_privkey

[Peer]
PublicKey = srvlan_pubkey
AllowedIPs = 10.0.1.0/24
Endpoint = srvlan_lanhostname:50000

यह मेरा फ़ायरवॉल है srvlan

# nft list ruleset
table inet firewall {
        chain inbound {
                type filter hook input priority filter; policy drop;
                ct state established,related accept
                ct state invalid drop
                iif "lo" accept
                ip protocol icmp accept
                ip6 nexthdr ipv6-icmp accept
                ip protocol igmp accept
                tcp dport 22 accept
                iifname "eno1" tcp dport { 80, 443 } ct state new accept
                iifname "eno1" udp dport 50000 ct state new accept
                iifname "wg0" udp dport 53 ct state new accept
                iifname "wg0" tcp dport { 80, 443 } ct state new accept
                iifname "wg0" udp dport 50000 ct state new accept
        }

        chain forward {
                type filter hook forward priority filter; policy drop;
                ct state established,related accept
                ct state invalid drop
                iifname "wg0" oifname "eno1" ct state new accept
        }

        chain outbound {
                type filter hook output priority filter; policy accept;
                ct state invalid drop
        }
}
table ip router {
        chain prerouting {
                type nat hook prerouting priority filter; policy accept;
        }

        chain postrouting {
                type nat hook postrouting priority srcnat; policy accept;
                oifname "eno1" ip saddr 10.0.1.0/24 masquerade
        }
}

जवाब

A.B Aug 26 2020 at 00:35

जब श्रीवैलन वायरगार्ड-टनल ट्रैफिक को आगे बढ़ाता है, तो वह इसे wg0 से प्राप्त करता है और इसे मार्गों ... wg0 फिर से: दो बार एक ही इंटरफ़ेस।

करने के लिए इस प्रविष्टि तो तुम संलग्न करने के लिए की जरूरत है मंत्रिमंडल आगे फ़ायरवॉल की श्रृंखला nftables :

                iifname "wg0" oifname "wg0" accept

अन्य मुद्दों, इनबाउंड श्रृंखला में :


                ip protocol icmp accept
                ip6 nexthdr ipv6-icmp accept
                ip protocol igmp accept

जबकि प्रोटोकॉल IPv4 के लिए काम करता है, प्रोटोकॉल में nexthdr IPv6 इस बात की गारंटी नहीं देता कि अगला हैडर ICMPv6 होगा: फिक्स्ड हैडर और अपर-लेयर प्रोटोकॉल हेडर के बीच कई एक्सटेंशन हेडर हो सकते हैं । यदि इस तरह के एक्सटेंशन हेडर कुछ पैकेट में दिखाई देते हैं, तो nexthdr ipv6-icmpअब मेल नहीं खाएंगे। IPv4 और IPv6 के लिए सही सिंटैक्स का उपयोग करें:

                meta nfproto ipv4 meta l4proto icmp accept
                meta nfproto ipv6 meta l4proto ipv6-icmp accept
                meta nfproto ipv4 meta l4proto igmp accept

Nftables संस्करण के आधार पर , इसे और अधिक सरलीकृत रूप में प्रदर्शित किया जाएगा।


                iifname "wg0" udp dport 50000 ct state new accept

पोर्ट 50000 वायरगार्ड इंटरफ़ेस के अंदर दिखाई नहीं देता है (जब तक आप वायरगार्ड के भीतर वायरगार्ड को सुरंग नहीं करना चाहते हैं), लेकिन बाहर (जिसके लिए पहले से ही एक नियम है)। इसकी जरूरत नहीं होनी चाहिए।


याद रखें कि जब आप अधिक वायरगार्ड क्लाइंट / साथियों को जोड़ते हैं (जैसा आपने सही ढंग से किया था), कि srvlan की AllowedIPs प्रविष्टियों में ओवरलैप्स नहीं हो सकते हैं क्योंकि वे मानक मार्ग के बाद, पर्याप्त सहकर्मी का चयन करने के लिए वायरगार्ड में होने वाले क्रिप्टोराउटिंग को निर्धारित करते हैं। इसके अलावा, अगर gcp_client के माध्यम से जोड़ता है srvlan सर्वरों के लिए WireGuard सुरंगों का इस्तेमाल नहीं, तो उनके लैन पता भी दोनों में जोड़ा जाना चाहिए AllowedIPs और की रूटिंग तालिका gcp_clientAllowedIPs का उपयोग उसके स्रोत के आधार पर एक पैकेट को स्वीकार करने के लिए किया जाता है (और निर्धारित करें कि कौन सा सहकर्मी और शायद रोमिंग के मामले में अपने समापन बिंदु को अपडेट करें), और यह निर्धारित करने के लिए कि कौन सा सहकर्मी अपने गंतव्य के आधार पर एक पैकेट भेज सकता है।