वायरगार्ड सर्वर और क्लाइंट एक दूसरे को पिंग करने में सक्षम हैं, लेकिन वायरगार्ड क्लाइंट एक दूसरे को पिंग करने में असमर्थ हैं
मैं एक वायरगार्ड कॉन्फ़िगरेशन स्थापित कर रहा हूं जहां मेरे पास निम्नलिखित इकाइयां हैं:
दूरस्थ VM उदाहरण पर होस्ट करता है जैसे कि Google क्लाउड या अमेज़ॅन aws। यह मेरे वायरगार्ड सर्वर का रिमोट क्लाइंट है। इसको बुलाते हैं
gcp_client
मेरे LAN पर होस्ट की गई मशीन पर वायरगार्ड सर्वर। चलो यह कहते हैं
srvlan
।
- इस उपकरण पर IPv4 अग्रेषण सक्षम है
sysctl
। - WAN और मेरे LAN के बीच एक Ubiquiti Edgerouter 4 है। मैंने इस डिवाइस पर पोर्ट फ़ॉरवर्डिंग और हेयरपिन NAT को सक्षम किया है। मैंने इस राउटर पर एक गतिशील डीएनएस भी स्थापित किया है।
- मेरे LAN पर एक या अधिक क्लाइंट, जो रिमोट क्लाइंट से कनेक्ट करने में सक्षम होना चाहिए जैसे कि यह मेरे LAN पर एक मशीन था। जैसा कि मैं अपने पहले ग्राहक के साथ समस्या का सामना कर रहा हूं, चलो इसे कॉल करें
client1
।
मेरे सेटअप में, मैं srvlan
और gcp_client
दोनों तरीकों के बीच, और बीच में client1
और srvlan
साथ ही साथ पिंग करने में सक्षम हूं । तथापि। से पिंग gcp_client
करने के लिए client1
(और इसके विपरीत) असफल।
के परिणामों को पढ़ने के आधार पर tcpdump -i wg0 -n icmp
, मैंने निम्नलिखित अवलोकन किए:
- से पिंग
client1
करने के लिएgcp_client
तक पहुँचनेsrvlan
लेकिन रूटर अग्रेषित नहीं कर रहे हैं। - मेरे राउटर तक पहुंचने के
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
}
}
जवाब
जब श्रीवैलन वायरगार्ड-टनल ट्रैफिक को आगे बढ़ाता है, तो वह इसे 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_client । AllowedIPs का उपयोग उसके स्रोत के आधार पर एक पैकेट को स्वीकार करने के लिए किया जाता है (और निर्धारित करें कि कौन सा सहकर्मी और शायद रोमिंग के मामले में अपने समापन बिंदु को अपडेट करें), और यह निर्धारित करने के लिए कि कौन सा सहकर्मी अपने गंतव्य के आधार पर एक पैकेट भेज सकता है।