मेरे पास दो इंटरफेस के साथ एक क्रंचबैंग वीएम है, eth0
और eth1
, जिनमें से प्रत्येक एक ओपनवार्ट वीएम ( eth0
होने 10.232.64.20
और
eth1
होने 10.232.65.20
) से जुड़ता है । मैं नेटवर्क मैनेजर और डीएचसीपी का उपयोग कर रहा हूं। मेरा समग्र लक्ष्य कई ssh
कनेक्शन है, और उनके साथ संबंध है ifenslave
।
डिफ़ॉल्ट रूप से eth1
(किसी कारण से) डिफ़ॉल्ट गेटवे है:
user@crunchbang:~$ ip ro
default via 10.232.65.1 dev eth1 proto static
10.232.64.0/24 dev eth0 proto kernel scope link src 10.232.64.20
10.232.65.0/24 dev eth1 proto kernel scope link src 10.232.65.20
मैंने इसके लिए एक मार्ग जोड़ा eth0
:
user@crunchbang:~$ sudo ip route add default via 10.232.64.1 dev eth0 proto static metric 1
फिर मेरे पास दो मार्ग हैं:
user@crunchbang:~$ ip ro
default via 10.232.65.1 dev eth1 proto static
default via 10.232.64.1 dev eth0 proto static metric 1
10.232.64.0/24 dev eth0 proto kernel scope link src 10.232.64.20
10.232.65.0/24 dev eth1 proto kernel scope link src 10.232.65.20
हालांकि, ssh
केवल के माध्यम से बाहर हो जाता है eth1
:
user@crunchbang:~$ ssh -b 10.232.64.20 user@1.2.3.4
ssh: connect to host 1.2.3.4 port 22: Connection timed out
user@crunchbang:~$ ssh -b 10.232.65.20 user@1.2.3.4
Enter passphrase for key '/home/user/.ssh/id_rsa':
eth0
मीट्रिक मेरे पास बदलने के बाद :
user@crunchbang:~$ ip ro
default via 10.232.64.1 dev eth0 proto static metric 1
default via 10.232.65.1 dev eth1 proto static metric 2
10.232.64.0/24 dev eth0 proto kernel scope link src 10.232.64.20
10.232.65.0/24 dev eth1 proto kernel scope link src 10.232.65.20
और अब ssh
केवल इसके माध्यम से बाहर निकलता है eth0
:
user@crunchbang:~$ ssh -b 10.232.64.20 user@1.2.3.4
Enter passphrase for key '/home/user/.ssh/id_rsa':
user@crunchbang:~$ ssh -b 10.232.65.20 user@1.2.3.4
ssh: connect to host 1.2.3.4 port 22: Connection timed out
मैं ssh
एक उच्च मीट्रिक के साथ एक इंटरफ़ेस का उपयोग करने के लिए कैसे मजबूर करूं ?
संपादित करें
मैंने 4.2 में कॉन्फ़िगरेशन को लागू और परीक्षण किया है । लिनक्स उन्नत रूटिंग एंड ट्रैफिक कंट्रोल HOWTO के कई अपलिंक / प्रदाता खंड के लिए रूटिंग। यह देखते हुए कि विन्यास सरल है, और यह कि मैंने त्रुटियों का सामना नहीं किया है, मैं केवल न्यूनतम स्पष्टीकरण के साथ कोड और परिणाम दिखाऊंगा।
root@crunchbang:~# ip route add 10.232.64.0/24 dev eth0 src 10.232.64.20 table T0
root@crunchbang:~# ip route add default via 10.232.64.1 table T0
root@crunchbang:~# ip route add 10.232.65.0/24 dev eth1 src 10.232.65.20 table T1
root@crunchbang:~# ip route add default via 10.232.65.1 table T1
root@crunchbang:~# ip route flush table main
root@crunchbang:~# ip route add 10.232.64.0/24 dev eth0 src 10.232.64.20
root@crunchbang:~# ip route add 10.232.65.0/24 dev eth1 src 10.232.65.20
root@crunchbang:~# ip rule add from 10.232.64.20 table T0
root@crunchbang:~# ip rule add from 10.232.65.20 table T1
root@crunchbang:~# ip route add default scope global nexthop via 10.232.64.1 dev eth0 weight 1 nexthop via 10.232.65.1 dev eth1 weight 1
यहां राउटिंग टेबल उत्पन्न किए गए हैं:
root@crunchbang:~# ip route show table T0
default via 10.232.64.1 dev eth0
10.232.64.0/24 dev eth0 scope link src 10.232.64.20
root@crunchbang:~# ip route show table T1
default via 10.232.65.1 dev eth1
10.232.65.0/24 dev eth1 scope link src 10.232.65.20
root@crunchbang:~# ip ro
default
nexthop via 10.232.64.1 dev eth0 weight 1
nexthop via 10.232.65.1 dev eth1 weight 1
10.232.64.0/24 dev eth0 scope link src 10.232.64.20
10.232.65.0/24 dev eth1 scope link src 10.232.65.20
उस विन्यास के साथ, ssh दोनों इंटरफेस के माध्यम से जुड़ता है:
user@crunchbang:~$ ssh -b 10.232.64.20 user@1.2.3.4
Enter passphrase for key '/home/user/.ssh/id_rsa':
user@crunchbang:~$ ssh -b 10.232.65.20 user@1.2.3.4
Enter passphrase for key '/home/user/.ssh/id_rsa':
हालाँकि, ऐसा प्रतीत होता है कि मुझे नेटवर्क मैनेजर को खोने की आवश्यकता है। अगर कोई समझा सकता है कि यह एक बुरा विचार क्यों है, या नुकसान की चेतावनी है, तो मैं इसकी सराहना करूंगा।
EDIT2
नेटवर्क प्रबंधक को हटाना अच्छी तरह से चला गया। मेरा सिर्फ एक आखिरी सवाल है। बूट पर कॉन्फ़िगरेशन को लोड करने का वर्तमान मानक तरीका क्या है?