现在的位置: 首页FreeBSD>正文
FreeBSD双网卡同网段同网关遇到的问题
2011年10月13日 FreeBSD 评论关闭 ⁄ 被围观 7,588 次+

freebsd配置了双网卡同网段同网关后遇到的问题,不论怎么访问这两个IP,通过systat -if命令查看两块网卡都有in方向的流量,而out方向的流量都走默认第一块网卡,第二块网卡out方向的流量始终为0,很是纳闷,以前在windows用过没有这种情况,于是baidu,google了一翻,找到了一位和我有相同遭遇的。他的环境是RHEL,以下是引用这位仁兄的文章,如下:

今天在CU看到一个问题:http://linux.chinaunix.net/bbs/thread-1021489-1-1.html
关于双网卡设置同一网段IP然后连接交换机的时候出现的奇怪现象。当时没有怎么思考、以为是生成树的缘故,不过后来一想不太对。
初步做了一下实验:

服务器为RHEL5 双网卡,eth0为234,eth1为233,我本地客户机为172。
RHEL: ifconfig如下:
[root@server1 ~]# ifconfig
eth0      Link encap:Ethernet HWaddr 00:0C:29:A5:D5:A3
inet addr:60.232.83.233 Bcast:60.232.83.255 Mask:255.255.255.128
略。。。。。。。
eth1      Link encap:Ethernet HWaddr 00:0C:29:A5:D5:AD
inet addr:60.232.83.234 Bcast:60.232.83.255 Mask:255.255.255.128
略。。。。。。。。。
lo        Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
略。。。。。。。。。
在客户机XP上ping两个地址,都是通的。
C:\ >ping 60.232.83.233
Pinging 60.232.83.233 with 32 bytes of data:
Reply from 60.232.83.233: bytes=32 time=9ms TTL=64
Reply from 60.232.83.233: bytes=32 time<1ms TTL=64
C:\ >ping 60.232.83.234
Pinging 60.232.83.234 with 32 bytes of data:
Reply from 60.232.83.234: bytes=32 time<1ms TTL=64
Reply from 60.232.83.234: bytes=32 time<1ms TTL=64
此时用arp –a在本地查看
C:\ >arp -a
Interface: 60.232.83.172 --- 0x20005
Internet Address      Physical Address      Type
60.232.83.129         00-04-96-1a-ca-60     dynamic
60.232.83.233         00-0c-29-a5-d5-a3     dynamic
60.232.83.234         00-0c-29-a5-d5-a3     dynamic

发现两个网卡的MAC地址一样,也就是eth0的mac地址。
现在我们[root@server1 ~]# ifconfig eth1 down
来禁止eth1,结果ping 233和234的地址都是通的。
这里可以这样理解,arp –a看到本地解析到得两块网卡mac地址是一样的,局域网是通过2层寻址的不可能涉及到ip这样的3层协议,因此mac地址相同ping哪个都应该是通 的,但是为什么本地会出现不同的IP相同的mac地址呢?在linux上看到的明明是不同的MAC地址00:0C:29:A5:D5:A3,00:0C:29:A5:D5:AD
继续测试,现在把eth0禁止。
[root@server1 ~]# ifconfig eth0 down
[root@server1 ~]# ifconfig
eth1      Link encap:Ethernet HWaddr 00:0C:29:A5:D5:AD
inet addr:60.232.83.234 Bcast:60.232.83.255 Mask:255.255.255.128
inet6 addr: fe80::20c:29ff:fea5:d5ad/64 Scope:Link
略。。。。。
lo        Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
略。。。。
本地先arp –d清除一下缓存。然后再ping两块网卡的IP地址,依然可以ping通两个地址。
Arp –a后发现:
C:\>arp -a
Interface: 60.232.83.172 --- 0x20005
Internet Address      Physical Address      Type
60.232.83.129         00-04-96-1a-ca-60     dynamic
60.232.83.233         00-0c-29-a5-d5-ad     dynamic
60.232.83.234         00-0c-29-a5-d5-ad     dynamic

MAC地址成为另一块也就是eth1的MAC地址。
然后开启eth0,然后再ping测试一下。结果如下:
C:\>arp -a
Interface: 60.232.83.172 --- 0x20005
Internet Address      Physical Address      Type
60.232.83.129         00-04-96-1a-ca-60     dynamic
60.232.83.233         00-0c-29-a5-d5-a3     dynamic
60.232.83.234         00-0c-29-a5-d5-ad     dynamic

这才是一张正常的地址表。
这时候再关闭eth0,结果就ping不通了,因为这时候缓存里的233的mac地址已经关闭。
Arp –d之后就可以ping通了,此时eth0依然处于关闭状态,只是清楚了一下缓存表,这样再起ping233地址,可以ping通了,得出的结果是234的mac地址。
C:\>arp -a
Interface: 60.232.83.172 --- 0x20005
Internet Address      Physical Address      Type
60.232.83.129         00-04-96-1a-ca-60     dynamic
60.232.83.233         00-0c-29-a5-d5-ad     dynamic
60.232.83.234         00-0c-29-a5-d5-ad     dynamic

此时开启eth0,现在本地缓存中的两个IP依然对应的还是234的mac地址。Arp –d清除一下,这次先ping 234再ping 233,结果两个都是233的既eth0的mac地址。
实验做到这里脑子有点乱,把这台linux服务器换成Windows Server 2003,就没有这问题出现。
C:\Documents and Settings\Administrator>ipconfig /all
Windows IP Configuration
Host Name . . . . . . . . . . . . : newxyz-yz5l2clv
Primary Dns Suffix . . . . . . . :
Node Type . . . . . . . . . . . . : Unknown
IP Routing Enabled. . . . . . . . : No
WINS Proxy Enabled. . . . . . . . : No
Ethernet adapter 本地连接 3:
Connection-specific DNS Suffix . :
Description . . . . . . . . . . . : VMware Accelerated AMD PCNet Adapter #2
Physical Address. . . . . . . . . : 00-0C-29-68-03-AF
DHCP Enabled. . . . . . . . . . . : No
IP Address. . . . . . . . . . . . : 60.232.83.251
Subnet Mask . . . . . . . . . . . : 255.255.255.128
Default Gateway . . . . . . . . . :
Ethernet adapter 本地连接 2:
Connection-specific DNS Suffix . :
Description . . . . . . . . . . . : VMware Accelerated AMD PCNet Adapter
Physical Address. . . . . . . . . : 00-0C-29-68-03-A5
DHCP Enabled. . . . . . . . . . . : No
IP Address. . . . . . . . . . . . : 60.232.83.250
Subnet Mask . . . . . . . . . . . : 255.255.255.128
Default Gateway . . . . . . . . . :
本地ping两块网卡之后显示如下:
C:\Documents and Settings\Administrator>arp -a
Interface: 60.232.83.198 --- 0x10005
Internet Address      Physical Address      Type
60.232.83.129         00-04-96-1a-ca-60     dynamic
60.232.83.250         00-0c-29-68-03-a5     dynamic
60.232.83.251         00-0c-29-68-03-af     dynamic

关闭任何一个网卡都是无法ping的。
所以在linux下网卡可能采用一些机制,比如说,首先,问题属于双网卡同一网段linux系统网卡自动路由的问题。
2、如果系统有两个独立网卡,并且这两个网卡的IP属于同一个子网,那么后面这个网卡的IP将自动路由到前面一个网卡上。
也就是说数据将自动路由到前面的那个网卡上。在不加任何设置的情况下,如果前面的网卡断线或者故障了(拔掉网线或者网卡指坏了),必须用命令down调后 面的网卡然后再up,这时后面的网卡才能启用。此时两个IP又同时路由到后面的网卡上,也就是说后面的网卡又具有两个IP地址。
当然两块网卡设置成同一网段是不合理的。
我的技术实在有限,这些都是实验后的猜测,就当抛砖引玉,希望有人能给解释一下。谢谢
改天实验一下bond~~~~
====================
结论:

这种现象正常。我们将其理解为在Linux系统下双网卡设置同样网段没有正确更新路由表的能力。因此会造成上述情况出现。
所以最好的方法是避免这样操作。
====================
本文地址:http://www.92csz.com/15/969.html
如非注明则为本站原创文章,欢迎转载。转载请注明转载自:moon's blog
 

抱歉!评论已关闭.