在 Linux 系统中,网卡名的规则有两种:传统网卡名和预测性网卡名。
01
传统网卡名和预测性网卡名
简单介绍
传统网卡名
在较早的 Linux 发行版中,网卡命名采用传统的命名方式,通常以 eth 开头,后面跟着数字,例如 eth0、eth1、eth2 等。这种方式简单直观,但在多网卡设备和热插拔场景下,可能导致网卡名发生变化,不够稳定。
预测性网卡名
为了解决传统网卡名不稳定的问题,现代 Linux 发行版引入了预测性网卡名(consistent network device naming),采用较为规范的命名方式,例如eno、 ens、enp 等前缀。这些前缀代表了不同的网络设备类型和设备位置,结合设备的物理位置和 MAC 地址,使网卡名更加稳定和可预测。
? eno:代表 Ethernet Onboard,表示主板上的集成网卡。
? ens:代表 Ethernet 槽位(slot),后面可能跟着数字表示不同的网卡设备。
? enp:代表 Ethernet 物理位置(path)。
根据预测性网卡名规则,网卡名可以是类似 ens0、eno1、enp3s0 等。
预测性网卡名的引入使得网卡命名更加一致和可预测,便于管理员管理和配置网络设备。但在某些特殊情况下,可能仍然会使用传统网卡名。在不同的 Linux 发行版中,可能会有不同的网卡名规则,默认情况下大多数现代 Linux 发行版都采用预测性网卡名。
02
预测性网卡名详细说明
systemd-udevd服务
systemd-udevd采用的预测性网络接口命名方案,服务文件位置是/lib/systemd/system/systemd-udevd.service。
预测性网卡名称由 systemd-udevd.service内置 net_id 生成并导出为 udev 属性
- ID_NET_NAME_ONBOARD
- ID_NET_LABEL_ONBOARD
- ID_NET_NAME_PATH
- ID_NET_NAME_SLOT
命名方案
man systemd.net-naming-scheme帮助可以查看命名的详解
man systemd.net-naming-scheme
整体结构为: prefix+net_id 即 前缀加udev的属性
基于接口类型的两个字符前缀
所有名称都以两个字符的前缀开头,表示接口类型。
前缀 | 含义 | 示例 |
en | Ethernet以太网 | ens1f1 |
wl | WLAN无线局域网 | wlp1s0 |
ww | WWAN无线广域网 | wwp1s0 |
ib | InfiniBand 无限带宽 | ibp1s0 |
sl | Serial line IP(slip)串行线ip | slp1s0 |
注:tun和tap是虚拟(隧道)网卡,主要是用户隧道和虚拟化环境。
udev net_id
内置函数导出以下 udev 设备属性:(这部分比较枯燥,有精力可以仔细研究)
属性 | 含义 | 示例 |
ID_NET_NAME_ONBOARD =prefixonumber | 板载设备的固件给出的序列数字,名称由前缀、字母 o 和固件指定的数字组成。这仅适用于 PCI 设备。 | eno1 |
ID_NET_NAME_SLOT =prefix[Pdomain]sslot[ffunction][nport_name|ddev_port] | 该属性描述了插槽位置。根据总线类型使用不同的方案,对于 USB、BCMA 和 SR-VIO 设备,全名由前缀、PCI 插槽标识符以及 USB 或 BCMA 或 SR-VIO 插槽标识符组成。 | ens1f0 |
ID_NET_NAME_PATH =prefix[Pdomain]pbussslot[ffunction][nport_name|ddev_port] | 该属性描述设备安装位置。根据总线类型使用不同的方案,对于 BCMA 和 USB 设备,必须知道 PCI 路径信息,全名由前缀、PCI 插槽标识符和 USB 或 BCMA 位置组成。 | enp2s0 |
ID_NET_NAME_MAC =prefixxAABBCCDDEEFF | 名称由前缀、字母 x 和 MAC 地址的 12 个十六进制数字组成。网卡替换时会发生改变。 | enx525400d5e0fb |
ID_NET_LABEL_ONBOARD =prefix label | 该属性是根据板载设备固件给出的文本标签设置的。该名称由与标签连接的前缀组成。这仅适用于 PCI 设备 | onboard_eth0 |
Slot槽位命名方案
(这部分比较枯燥,有精力可以仔细研究)
格式 | 含义 |
prefix [Pdomain] sslot [ffunction] [nport_name | ddev_port] | PCI插槽序号 |
prefix vslot | VIO 插槽号 (IBM PowerVM) |
prefix [Pdomain] sslot [ffunction] [nport_name | ddev_port] bnumber | Broadcom 总线 (BCMA) 核心序号 |
prefix [Pdomain] sslot [ffunction] [nport_name | ddev_port] uport... [cconfig] [iinterface] | USB 端口序号 |
prefix [Pdomain] sslot [ffunction] [nport_name | ddev_port] vslot | SR-VIO 插槽序号 |
网卡命名相关文件
udev是一个用户空间的设备管理工具,负责在Linux系统启动过程中为设备分配唯一的设备文件,并根据设备属性和规则进行设备的自动配置。udev规则文件定义了当特定类型的设备插入或移除时应执行的操作。(这部分比较枯燥,有精力可以仔细研究)
文件 | 说明 | 备注 |
/usr/lib/udev/rules.d/ | udev设备管理器使用的规则文件,用于自动识别和配置Linux系统中的设备 | 这些规则文件根据其数字前缀的顺序依次执行,数字越小,优先级越高。这些规则文件包含了对不同类型的设备进行识别和配置的规则。 |
/etc/udev/rules.d/ | 用于存放udev规则文件的目录,这些规则文件定义了设备管理器在特定事件发生时应执行的操作。 | 通过编辑这些规则文件,可以自定义和配置系统中各种设备的行为。 |
/usr/lib/systemd/network/ | 用于配置网络接口的systemd网络配置文件 | 默认情况下根据 |
/sys/devices/*/*/*/net | 该目录是访问Linux系统中的网络接口设备 | 在每个接口设备目录中,您可以找到与该接口相关的配置和状态信息 |
99-default.link中NamePolicy说明
接口名称应遵循的有序、以空格分隔的策略列表,可通过在内核命令上指定net.ifnames=0来禁用NamePolicy=*。(修改内核参数生效的逻辑)
NamePolicy值 | 说明 |
keep | 保留用户空间给设备指定的名称 |
kernel | 如果内核声称它为设备设置的名称是可预测的,则不会执行重命名。 |
database | 根据 udev 的硬件数据库中具有键 ID_NET_NAME_FROM_DATABASE 的条目设置的 |
onboard | 板载设备的固件来命名,udev属性是ID_NET_NAME_ONBOARD |
slot | 固件的可热插拔的设备来命名,udev属性是ID_NET_NAME_SLOT |
path | 根据设备的物理位置设置命名,udev对应的属性是 ID_NET_NAME_PATH |
mac | 设备的mac地址命名,由udev的ID_NET_NAME_MAC属性展示。 |
Ubuntu 20默认配置,优先级为:keep -> kernel -> database -> onboard -> slot -> path
# cat /usr/lib/systemd/network/99-default.link
[Match]
OriginalName=*
[Link]
NamePolicy=keep kernel database onboard slot path
AlternativeNamesPolicy=database onboard slot path
# cat /usr/lib/systemd/network/73-usb-net-by-mac.link
[Match]
Path=*-usb-*
[Link]
NamePolicy=mac
优先级
默认情况下,systemd 将使用以下策略命名接口以应用支持的命名方案(以CentOS为例,比较经典 ):
方案 | 描述 | 示例 |
1 | 设备名称包含固件或者 BIOS 提供的索引号,用于板上的设备。如果此信息不可用或不适用,则 udev 将使用方案 2。 | eno1 |
2 | 设备名称包含固件或 BIOS 提供的 PCI Express(PCIe)热插件插槽索引号。如果此信息不可用或不适用,则 udev 将使用方案 3。 | ens1 |
3 | 设备名称包含硬件连接器的物理位置。如果此信息不可用或不适用,则 udev 将使用方案 5。 | enp2s0 |
4 | 设备名称包含 MAC 地址。Red Hat Enterprise Linux 默认不使用这个方案,但管理员可选择性地使用它。 | enx525400d5e0fb |
5 | 传统的无法预计的内核命名方案。如果 udev 无法应用任何其他方案,则设备管理器使用这个方案。 | eth0 |