
當我在多個介面上時,如何知道路由器的位址是什麼?我知道透過使用 netstat -rn 我可以獲得主介面的網關,即路由器的位址。但其他介面呢?
就我而言,我在不同路由器上的 eth0 和 wlan0 上,作業系統選擇 eth0 作為預設值,但是有沒有一種通用方法可以查詢介面的路由器位址?
$ netstat -rn
Kernel IP routing table
Destination Gateway Genmask Flags MSS Window irtt Iface
0.0.0.0 192.168.1.1 0.0.0.0 UG 0 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 0 0 0 wlan0
192.168.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
192.168.2.0 0.0.0.0 255.255.255.0 U 0 0 0 wlan0
$ ifconfig
eth0 Link encap:Ethernet HWaddr b4:b5:2f:32:f3:22
inet addr:192.168.1.132 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::b6b5:2fff:fe32:f322/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:22 errors:0 dropped:0 overruns:0 frame:0
TX packets:53 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:3035 (3.0 KB) TX bytes:9857 (9.8 KB)
Interrupt:17 Memory:d4400000-d4420000
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:569 errors:0 dropped:0 overruns:0 frame:0
TX packets:569 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:53950 (53.9 KB) TX bytes:53950 (53.9 KB)
wlan0 Link encap:Ethernet HWaddr 60:67:20:00:56:6c
inet addr:192.168.2.115 Bcast:192.168.2.255 Mask:255.255.255.0
inet6 addr: fe80::6267:20ff:fe00:566c/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:8152 errors:0 dropped:0 overruns:0 frame:0
TX packets:4030 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:6316155 (6.3 MB) TX bytes:574275 (574.2 KB)
答案1
不是一個完整的解決方案,但你檢查一下arp -n
。
ddd@mmm ~ $ arp -n
Address HWtype HWaddress Flags Mask Iface
xxx.xxx.xxx.xxx ether 00:e0:1e:b4:12:42 C eth0
yyy.yyy.yyy.yyy ether 00:14:78:52:28:d2 C wlan0
答案2
要找到第一個用於存取互聯網的hopan介面:
ping -I <interface or ip of interface> -t 1 8.8.8.8
-t 1 - 將資料包的 ttl 限制為 1,這表示資料包將被它嘗試通過的第一個路由器殺死。該路由器將傳回「超出生存時間」封包,顯示產生該封包的裝置的 IP 位址。
From 192.168.0.254 icmp_seq=1 Time to live exceeded
在 Windows 上,命令略有不同:
ping -S <ip address of interface> -i 1 8.8.8.8
-i 1 是 Windows 上將 ttl 限制為 1 的選項,回復將是:
Reply from 192.168.0.254: TTL expired in transit.
如果增加 -t/-i 之後的數字,那麼您將獲得資料包經過的第 n 跳。如果您沒有 Tracert,並且您需要知道資料包將採取的路徑,則可以使用此技術。
請注意,每次發送資料包時,資料包在網際網路和某些區域網路上所採用的路由可能會發生變化。