Centos 7中的网卡一致性命名规则

一致性网络设备命名,即Consistent Network Device Naminghtml

1、为何须要这个

服务器一般有多块网卡,有板载集成的,同时也有插在PCIe插槽的。linux

Linux系统的命名原来是eth0,eth1这样的形式,可是这个编号每每不必定准确对应网卡接口的物理顺序。ios

为解决这类问题,dell开发了biosdevname方案。数组

systemd v197版本中将dell的方案做了进一步的通常化拓展。服务器

目前的Centos既支持dell的biosdevname,也支持systemd的方案。网络

Centos <wbr>7中的网卡一致性命名规则

2、Centos7中的命名策略

Scheme 1: 若是从BIOS中可以取到可用的,板载网卡的索引号,则使用这个索引号命名,例如: eno1,如不能则尝试Scheme 2dom

Scheme 2: 若是从BIOS中可以取到能够用的,网卡所在的PCI-E热插拔插槽的索引号,则使用这个索引号命名,例如: ens1,如不能则尝试Scheme 3ide

Scheme 3:若是能拿到设备所链接的物理位置信息,则使用这个信息命名,例如:enp2s0,如不能则尝试Scheme 5ui

Scheme 5:传统的kernel命名方法,例如: eth0,这种命名方法的结果不可预知的,便可能第二块网卡对应eth0,第一块网卡对应eth1。google

Scheme 4 使用网卡的MAC地址来命名,这个方法通常不使用。

 

3、biosdevname和net.ifnames两种命名规范

net.ifnames的命名规范为:   设备类型+设备位置+数字

设备类型:

en 表示Ethernet

wl 表示WLAN

ww 表示无线广域网WWAN

设备位置:

Centos <wbr>7中的网卡一致性命名规则
实际的例子:

eno1 板载网卡

enp0s2  pci网卡

ens33   pci网卡

wlp3s0  PCI无线网卡

wwp0s29f7u2i2   4G modem

wlp0s2f1u4u1   链接在USB Hub上的无线网卡

enx78e7d1ea46da pci网卡

----------------------------------------

biosdevname的命名规范为

Centos <wbr>7中的网卡一致性命名规则

实际的例子:

em1 板载网卡

p3p4 pci网卡

p3p4_1 虚拟网卡

 

4、systemd中的实际执行顺序

按照以下顺序执行udev的rule

1./usr/lib/udev/rules.d/60-net.rules

2./usr/lib/udev/rules.d/71-biosdevname.rules

3./lib/udev/rules.d/75-net-description.rules

4./usr/lib/udev/rules.d/80-net-name-slot.rules

60-net.rules

使用/lib/udev/rename_device这个程序,去查询/etc/sysconfig/network-scripts/下全部以ifcfg-开头的文件

若是在ifcfg-xx中匹配到HWADDR=xx:xx:xx:xx:xx:xx参数的网卡接口

则选取DEVICE=yyyy中设置的名字做为网卡名称。

71-biosdevname.rules

若是系统中安装了biosdevname,且内核参数未指定biosdevname=0,且上一步没有重命名网卡,则按照biosdevname的命名规范,从BIOS中取相关信息来命名网卡。

主要是取SMBIOS中的type 9 (System Slot) 和 type 41 (Onboard Devices Extended Information)

不过要求SMBIOS的版本要高于2.6,且系统中要安装biosdevname程序。

75-net-description.rules

udev经过检查网卡信息,填写以下这些udev的属性值

ID_NET_NAME_ONBOARD

ID_NET_NAME_SLOT

ID_NET_NAME_PATH

ID_NET_NAME_MAC

80-net-name-slot.rules

若是在60-net.rules ,71-biosdevname.rules这两条规则中没有重命名网卡,且内核未指定net.ifnames=0参数

则udev依次尝试使用如下属性值来命名网卡,若是这些属性值都没有,则网卡不会被重命名。

ID_NET_NAME_ONBOARD

ID_NET_NAME_SLOT

ID_NET_NAME_PATH

上边的71-biosdevname.rules 是实际执行biosdevname的policy

75-net-description.rules和80-net-name-slot.rules实际执行Scheme 1,2,3

根据上述的过程,可见网卡命名受 biosdevname和net.ifnames这两个内核参数影响。

这两个参数均可以在grub配置中提供。

biosdevname=0是系统默认值(dell服务器默认是1),net.ifnames=1是系统默认值:

#vi /boot/grub/grub.conf

kernel /boot/vmlinuz biosdevname=1

initrd /boot/initrd.img

第二节所说的Scheme的策略顺序是系统默认的。

如系统BIOS符合要求,且系统中安装了biosdevname,且biosdevname=1启用,则biosdevname优先;

若是BIOS不符合biosdevname要求或biosdevname=0,则仍然是systemd的规则优先。

若是用户本身定义了udev rule来修改内核设备名字,则用户规则优先。

内核参数组合使用的时候,其结果以下:

默认内核参数(biosdevname=0,net.ifnames=1):  网卡名 "enp5s2"

biosdevname=1,net.ifnames=0:网卡名 "em1"

biosdevname=0,net.ifnames=0:网卡名 "eth0" (最传统的方式,eth0 eth1 傻傻分不清)

 

参考文档:

http://benjr.tw/93340

https://docs.google.com/viewer?url=http://domsch.com/linux/lpc2010/lpc2010-network-device-naming.pdf

https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/Networking_Guide/

http://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames/

http://blog.chinaunix.net/uid-14735472-id-4195429.html

相关文章
相关标签/搜索