मेरे लिनक्स पीसी में वर्चुअल एनआईसी कैसे जोड़ें, ताकि वे आईएसपी के डोमेन पर अपने एमएसीएस को उजागर करें?


1

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

इसलिए मुझे लगता है कि VBox को हल किए बिना उन वर्चुअल एनआईसी को अपने पीसी में जोड़ने का एक तरीका होना चाहिए। मैंने कोशिश की ip link add link enp0s3 type macvlan

ip netns add ns
ip link add link enp0s3 type macvlan
ip link set netns ns macvlan0
ip netns exec ns ip link set up macvlan0
ip netns exec ns ip addr add 192.168.222.101/24 dev macvlan0
ip addr add 192.168.222.1/24 dev enp0s3
ping 192.168.222.101
PING 192.168.222.101 (192.168.222.101) 56(84) bytes of data.
^C
--- 192.168.222.101 ping statistics ---
3 packets transmitted, 0 received, 100% packet loss, time 1999ms

मैंने भी कोशिश की ip link add link enp0s3 type macvlan mode bridgeऔर ip link add link enp0s3 type macvtap [mode bridge], लेकिन यह मदद नहीं करता है।

जवाबों:


1

सबसे आसान समाधान शायद उपयोग करना है macvlans। इसी तरह के समाधान macvtap और ipvlan हैं , जो ऊपर से केवल न्यूनतम रूप से भिन्न होते हैं; कई विवरणों के बिना, एक के बजाय दूसरे को चुनना मुश्किल है। लेकिन निम्नलिखित निश्चित रूप से काम करेगा।

प्रत्येक नेटवर्क नेमस्पेस के लिए, एक मैक्वलन इंटरफ़ेस निम्नानुसार असाइन करें:

 NNS=TheNameOfYourNetworkNamespace
 ip netns add $NNS
 ip link add link eth0 mac$NNS address 56:61:4f:7c:77:db type macvlan mode bridge
 ip link set dev mac$NNS netns $NNS

मैंने एक विशिष्ट मैक पते का उपयोग किया है, address 56:61:4f:7c:77:dbयदि आप इसे निर्दिष्ट करने में कोई रुचि नहीं रखते हैं, तो आप इस भाग को छोड़ सकते हैं, इस प्रकार इसे मौका देने के लिए छोड़ सकते हैं।

अब नेटवर्क नेमस्पेस दर्ज करें और नेटवर्क कॉन्फ़िगर करें:

 ip netns exec $NNS xterm

और खुले के भीतर से xtermकरें:

 ip link set dev $NAME_OF_MAC_INTERFACE up
 ip link set dev lo up
 ip addr add 127.0.0.1 dev lo
 dhclient -v mac$NNS

और आप कर रहे हैं

एक अंतिम टिप्पणी: mode bridgeऊपर उपयोग किया गया विकल्प सभी नेटवर्क नेमस्पेस को एक दूसरे से सीधे बात करने की अनुमति देता है, अर्थात एक स्विच के माध्यम से गुजरने के बिना। हालाँकि, आप इस तरह के विकल्प का उपयोग करते हैं या नहीं, आपका होस्ट नेटवर्क नेमस्पेस से बात करने में असमर्थ होगा, जब तक कि आप स्वयं होस्ट के लिए मैक्वलन का निर्माण नहीं करते हैं, उस स्थिति में यह अन्य एनएनएस के साथ संवाद करने में सक्षम होगा जैसे कि यह स्वयं उनमें से एक थे।

संपादित करें:

यह काम नहीं करता है क्योंकि मुझे यह याद रखना चाहिए कि, एनएनएस के अंदर एक बार $ एनएनएस जैसे पर्यावरण चर को अब परिभाषित नहीं किया गया है, इसलिए मुझे ऊपर की रेखा को सही करना चाहिए। वास्तव में, मेरे सिस्टम पर,

 # ip addr show dev eth0
   2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether e8:e0:b7:be:72:6a brd ff:ff:ff:ff:ff:ff
   inet 192.168.73.55/24 brd 192.168.73.255 scope global eth0
   valid_lft forever preferred_lft forever
   inet6 fe80::eae0:b7ff:febe:726a/64 scope link 
   valid_lft forever preferred_lft forever
  # NNS=ns1
  # ip netns add $NNS
  # ip link add link eth0 mac$NNS address 56:61:4f:7c:77:db type macvlan 
  # ip link set dev mac$NNS netns $NNS
  # ip netns exec $NNS /bin/bash
  # ip link set dev macns1 up
  #  ip link set dev lo up
  #  ip addr add 127.0.0.1 dev lo
  # dhclient -v macns1
    Internet Systems Consortium DHCP Client 4.2.4
    Copyright 2004-2012 Internet Systems Consortium.
    All rights reserved.
    For info, please visit https://www.isc.org/software/dhcp/

    Listening on LPF/macns1/56:61:4f:7c:77:db
    Sending on   LPF/macns1/56:61:4f:7c:77:db
    Sending on   Socket/fallback
    DHCPDISCOVER on macns1 to 255.255.255.255 port 67 interval 3 (xid=0x473d2846)
    DHCPREQUEST of 192.168.73.48 on macns1 to 255.255.255.255 port 67 (xid=0x46283d47)
    DHCPOFFER of 192.168.73.48 from 192.168.73.1
    DHCPACK of 192.168.73.48 from 192.168.73.1
    bound to 192.168.73.48 -- renewal in 21288 seconds.
  # ping -c1 superuser.com
    PING superuser.com (104.16.127.192) 56(84) bytes of data.
    64 bytes from 104.16.127.192: icmp_seq=1 ttl=53 time=12.9 ms

    --- superuser.com ping statistics ---
    1 packets transmitted, 1 received, 0% packet loss, time 0ms
    rtt min/avg/max/mdev = 12.927/12.927/12.927/0.000 ms

जैसा कि आप देख सकते हैं, यह पूरी तरह से मेरे सिस्टम पर काम करता है। आप देख सकते हैं कि NNS (192.168.73.48) के भीतर मुझे जो IP पता मिलता है, वह 192.168.73.55 होस्ट से अलग है।

यदि यह आपके सिस्टम पर काम नहीं करता है, तो मुझे कुछ और की आवश्यकता होगी, यह काम नहीं करता है , क्योंकि मैं आपकी त्रुटि को दोहराने में असमर्थ हूं।


मैंने आपका उत्तर देने की कोशिश की, लेकिन मुझे खेद है कि मैं आपको बता सकता हूं कि यह काम नहीं करता है। वास्तव में, मैंने कोशिश arp -sकी $NNSऔर यह देता है 192.168.42.129 (incomplete)। आईपी ​​मेरा प्रवेश द्वार है। मैं डिफ़ॉल्ट नामस्थान में कोशिश की यह सही मैक देता है।
TorosFanny

@TorosFanny Pls मेरा संपादन पढ़ें।
मारियसमैटुटिया

यह वास्तव में अजीब है। मैं आपको बताना भूल गया हूं, मैं अपने सभी प्रयोग वर्चुअलबॉक्स में करता हूं। एक बार जब मैंने अतिथि को उबंटू दिया bridged adapter, और फिर dhclient -v mac$NNSअसफल हो गया, और मैंने अतिथि को NATऔर फिर dhclient -v mac$NNSसफलता देने की कोशिश की । NATमोड के साथ , मैं भी कर सकता हूं ping -c1 superuser.com, लेकिन अभी भी अतिथि ओएस के डिफ़ॉल्ट नामस्थान के एनआईसी को पिंग नहीं कर सकता। यह वास्तव में अजीब है, यह बाहरी दुनिया को पिंग कर सकता है लेकिन एनआईसी इससे जुड़ा नहीं है। मैंने अपने असली पीसी के साथ आपके उत्तर की कोशिश की, यह ठीक काम करता है। शायद shared adapterमोड में कुछ गड़बड़ है। धन्यवाद।
TorosFanny
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.