linux下网卡漂移导致网络不可用

 

情景:linux系统,pc server服务器,内置双网卡,pci-e插槽一张双光纤口网卡。共四个以太网设备。

其中内置双网卡设置为端口绑定。热备模式。

 

一日服务器重启后,无法远程访问。

检查步骤

1、查看服务器网口,bond0的slave都没有起来。

2、restart network service 提示绑定的eth0 eth1 linkdown 检查线路。

3、查看ethtool eth0 和eth1 都提示link down

4、bond0绑定的是eht0 和eth1故无法启动。

5、检查ifcfg-eth0 和ifcfg-eth1 一切正常,但HWADDR未配置

6、网上查资料。。。。。。。

7、重新设置ifcfg-ethX的HWADDR绑定到每个实体网卡的MAC

8、重启解决。

 

故障分析:

因linux版本问题,如未对ethX的MAC地址进行绑定,可能会产生顺序漂移。

正常情况:

eth0:内置网卡(连线)

eth1:内置网卡(连线)

eth2:外置光纤网卡(未连线)

eth3:外置光纤网卡(未连线)

 

重启之后 发生漂移:

 

eth0:外置光纤网卡(未连线)

eth1:外置光纤网卡(未连线)

 

eth2:内置网卡(连线)

eth3:内置网卡(连线)


因bond0是和eth0 和eth1进行绑定,故无法启动。对网卡进行地址绑定之后,

重启服务器恢复。

发生网卡顺序漂移的原因不详。

 

参考:http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=1919509    1楼有详细

参考:

使用linux系统时会出现这样的情况,当你安装了某个网卡的驱动程序时,或者安装了与网卡相关的程序后。


网卡会出现所谓的漂移现象。(注意:不是飘逸)。可能的表象为:


(1):网卡顺序颠倒,比如之前你的网线连接的网口为eth0,当安装某个网卡的驱动后,可能它的名字变为eth0或者eth3,等等情况。


(2):网卡名字改变,这种情况倒不是eth0到eth1的改变,而是很诡异的变化,比如eth0找不到了,多了个网卡名字叫 __tmp3183921382193__


这个确实让人很恼火。因为有人可能会通过ifconfig | grep eth来获取信息从而完成一些开发工作,如果网卡名字变得乌七八糟了,程序肯定会出错。


(3):光口网卡和电口网卡顺序乱了,或者交叉。


总之我们的目的就是:能够指定某个网卡的名字为我们想要的物理设备。做法如下:


第一步,识别谁是谁。


要使用网卡,首现要知道哪个名字对应的哪个物理设备,做法为:从交换机拉一根网线,从上到下挨个接到网卡上面,注意每次只能接一个网卡,接上后通过ethtool命令来查看是否连着网线,比如


[root@AS5 ~]# ethtool eth0

Settings for eth0:

Supported ports: [ MII ]

Supported link modes:   10baseT/Half 10baseT/Full

                         100baseT/Half 100baseT/Full

                         1000baseT/Full

Supports auto-negotiation: Yes

Advertised link modes:  10baseT/Half 10baseT/Full

                         100baseT/Half 100baseT/Full

                         1000baseT/Full

Advertised auto-negotiation: Yes

Speed: 100Mb/s

Duplex: Full

Port: MII

PHYAD: 2

Transceiver: external

Auto-negotiation: on

Supports Wake-on: g

Wake-on: d

Link detected: yes


看到了eth0的状态为连接着网线。如果Linked detected:no,则说明没有连接网线。


如此区分开哪个设备的名字是什么,标注好。


第二步:获取每个网卡的MAC地址


ifconfig -a能看到所有网络设备。


通过 ifconfig -a | grep HWaddr 来获取每个设备的MAC地址。


比如:


[root@AS5 ~]# ifconfig  -a | grep HWaddr

eth0      Link encap:Ethernet  HWaddr 00:30:48:7F:B5:CA

eth1      Link encap:Ethernet  HWaddr 00:30:48:7F:B5:CB

eth2      Link encap:Ethernet  HWaddr 00:04:23:A6:81:E0

eth3      Link encap:Ethernet  HWaddr 00:04:23:A6:81:E1


拿到了每个网卡的MAC地址。


第三步:进行MAC和网卡名称绑定。


我们都知道,对于RedHat的系统,网络的配置文件在:/etc/sysconfig/network-scripts/ifcfg-ethX


中存着,N=0,1,2。。。


比如:root@AS5 ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0

# nVidia Corporation MCP55 Ethernet

DEVICE=eth0

ONBOOT=yes

HWADDR=00:30:48:7f:b5:ca

TYPE=Ethernet

NETMASK=255.255.255.0

IPADDR=192.168.42.231

GATEWAY=192.168.42.1

BOOTPROTO=static

#NAMESERVER=202.106.0.20


这个文件是对网卡进行初始化的配置文件。


比如如果我们想指定网卡MAC地址为MAC1的设备名称为ethn,那么,修改文件


/etc/sysconfig/network-scripts/ifcfg-ethn


在里面添加MAC地址绑定和名字的配置信息


DEVICE=ethn


HWADDR=MAC1(比如00:30:48:7f:b5:ca)


其它配置信息不受影响。


当对所有网卡实现绑定后,reboot系统,应该就可以了。


还有一点需要注意,就是驱动对应关系的文件:


/etc/modprobe.conf


要在该文件中修改,确保某个设备使用的就是对应它的驱动,比如:


cat /etc/modprobe.conf

alias eth0 forcedeth

alias eth1 forcedeth

alias scsi_hostadapter aic79xx

alias scsi_hostadapter1 sata_nv

alias scsi_hostadapter2 usb-storage

alias eth2 e1000

alias eth3 e1000


说明eth0和eth1用的forcedeth的驱动,eth2和eth3用的是e1000的驱动。

 

欢迎大家评论交流,发现博文中存在的问题一定要留言哦