多网卡识别顺序的问题
时间:2010-12-10
来源:互联网
Linux系统,4张网卡,两张 82576的,两张 82571EB 的。
初始安装的系统是CentOS 5.5,内核版本是2.6.18-194.el5xen
/etc/modprobe.conf 文件中关于网卡的内容如下:
可见两张 82576 网卡对应 eth0 和 eth1,均使用 igb 驱动。
两张 82571EB 网卡对应 eth2 和 eth3,均使用 e1000e 驱动。
这里我重新制作了内核安装包,使用 2.6.24 的内核。由于该版本内核并没有 igb 驱动。我从 intel 官方下载 igb 驱动,并移植到内核中。
但是进入 2.6.24 的内核下,发现 eth2 网卡没有启动。
同时,检查其他三张网卡:
发现 eth0 和 eth3 使用的 igb 驱动,eth2 使用了 e1000 驱动。而且根据 bus-info 可以看出,新的内核下,对四张网卡识别的顺序和安装的发行版上有所不同。
同时,查看 /proc/net/dev
发现有一个 __tmp 开头的接口。我怀疑应该是 eth2,只是没有别正确识别。
另外,常见的 /proc/net/dev 是按照 eth 的编号顺序显示的,这里也发生变化了。
请大家帮忙看一下是什么原因。
QUOTE:
01:00.0 Ethernet controller: Intel Corporation 82576 Gigabit Network Connection (rev 01)
01:00.1 Ethernet controller: Intel Corporation 82576 Gigabit Network Connection (rev 01)
04:00.0 Ethernet controller: Intel Corporation 82571EB Gigabit Ethernet Controller (rev 06)
04:00.1 Ethernet controller: Intel Corporation 82571EB Gigabit Ethernet Controller (rev 06)
01:00.1 Ethernet controller: Intel Corporation 82576 Gigabit Network Connection (rev 01)
04:00.0 Ethernet controller: Intel Corporation 82571EB Gigabit Ethernet Controller (rev 06)
04:00.1 Ethernet controller: Intel Corporation 82571EB Gigabit Ethernet Controller (rev 06)
初始安装的系统是CentOS 5.5,内核版本是2.6.18-194.el5xen
/etc/modprobe.conf 文件中关于网卡的内容如下:
QUOTE:
alias eth0 igb
alias eth1 igb
alias eth2 e1000e
alias eth3 e1000e
alias eth1 igb
alias eth2 e1000e
alias eth3 e1000e
可见两张 82576 网卡对应 eth0 和 eth1,均使用 igb 驱动。
两张 82571EB 网卡对应 eth2 和 eth3,均使用 e1000e 驱动。
这里我重新制作了内核安装包,使用 2.6.24 的内核。由于该版本内核并没有 igb 驱动。我从 intel 官方下载 igb 驱动,并移植到内核中。
但是进入 2.6.24 的内核下,发现 eth2 网卡没有启动。
同时,检查其他三张网卡:
QUOTE:
[root@xxx ~]# ethtool -i eth0
driver: igb
version: 2.4.8
firmware-version: 1.4-3
bus-info: 0000:01:00.0
[root@xxx ~]# ethtool -i eth1
driver: e1000
version: 7.3.20-k2-NAPI
firmware-version: 5.6-2
bus-info: 0000:04:00.1
[root@xxx ~]# ethtool -i eth3
driver: igb
version: 2.4.8
firmware-version: 1.4-3
bus-info: 0000:01:00.1
driver: igb
version: 2.4.8
firmware-version: 1.4-3
bus-info: 0000:01:00.0
[root@xxx ~]# ethtool -i eth1
driver: e1000
version: 7.3.20-k2-NAPI
firmware-version: 5.6-2
bus-info: 0000:04:00.1
[root@xxx ~]# ethtool -i eth3
driver: igb
version: 2.4.8
firmware-version: 1.4-3
bus-info: 0000:01:00.1
发现 eth0 和 eth3 使用的 igb 驱动,eth2 使用了 e1000 驱动。而且根据 bus-info 可以看出,新的内核下,对四张网卡识别的顺序和安装的发行版上有所不同。
同时,查看 /proc/net/dev
QUOTE:
Inter-| Receive | Transmit
face |bytes packets errs drop fifo frame compressed multicast|bytes packets errs drop fifo colls carrier compressed
lo:7476419692 1424305 0 0 0 0 0 0 7476419692 1424305 0 0 0 0 0 0
__tmp358702611: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
eth1:51413066439 479078418 0 536 0 0 0 1 1146871974797 787610625 0 0 0 0 0 0
eth0: 1825946 30420 0 0 0 0 0 0 1182 23 0 0 0 0 0 0
eth3:48131386965 459275416 0 0 0 0 0 0 1147067104897 789553247 0 0 0 0 0 0
bond0:99544453404 938353834 0 536 0 0 0 1 2293939079694 1577163872 0 0 0 0 0 0
face |bytes packets errs drop fifo frame compressed multicast|bytes packets errs drop fifo colls carrier compressed
lo:7476419692 1424305 0 0 0 0 0 0 7476419692 1424305 0 0 0 0 0 0
__tmp358702611: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
eth1:51413066439 479078418 0 536 0 0 0 1 1146871974797 787610625 0 0 0 0 0 0
eth0: 1825946 30420 0 0 0 0 0 0 1182 23 0 0 0 0 0 0
eth3:48131386965 459275416 0 0 0 0 0 0 1147067104897 789553247 0 0 0 0 0 0
bond0:99544453404 938353834 0 536 0 0 0 1 2293939079694 1577163872 0 0 0 0 0 0
发现有一个 __tmp 开头的接口。我怀疑应该是 eth2,只是没有别正确识别。
另外,常见的 /proc/net/dev 是按照 eth 的编号顺序显示的,这里也发生变化了。
请大家帮忙看一下是什么原因。
作者: Godbach 发布时间: 2010-12-10
参考:
使用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的驱动。
使用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的驱动。
作者: duanjigang 发布时间: 2010-12-10
2楼的回帖太明了了,收藏备用
作者: Godbach: 发布时间: 2010-12-10
受教了,我也MARK一下,有时候我也遇到过这样的问题
作者: chenyx 发布时间: 2010-12-10
duanjigang 兄的资料非常实用啊,谢谢。
BTW,duanjigang 有没研究过这种现象的深层次的原因啊
BTW,duanjigang 有没研究过这种现象的深层次的原因啊
作者: 程序c 发布时间: 2010-12-10
duan 兄的回复,也让我想起来了,以前的设备有更多网卡的情况下,生产系统时,有一个步骤就是要处理网卡顺序的工作。
本以为四张网卡不容易乱序,结果也出现了。
本以为四张网卡不容易乱序,结果也出现了。
作者: Godbach 发布时间: 2010-12-10
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28