1.问题现象
8 个网口, 命名从 eth1 开始到 eth8。 目前在系统 grub 里面加了 net.ifnames=0 biosdevname=0 参数, 然后在 udev 规则中加了一条固定网卡和硬件 pci 设备号的规则文件。 最后在 rc.local 中加了两条重新安装网卡驱动的命令( rmmod igb && modprobe igb) 。 然后重启就会生效。 但是重复开关机 10-20次后就会出现网卡顺序乱的情况、 比如说 eth5 没了, 多了一个 eth0。 然后重
启又好了。
udev 规则如下:
grub 参数如下:
2.问题分析
1) 测试环境重装 v10-desktop-sp1-2107 系统, 添加 8 块网卡, 重启后可以看到ip 信息如下:
查看 dmesg 日志, 可以看到 8 块网卡初始化 eth0-7,然后被预设的命名规则重命名为 ens33、 ens38、 ens39、 ens40、 ens41、 ens42、 ens43、 ens44
2) 此时如果在grub中不加net.ifnames=0 biosdevname=0参数, 但是添加如下udev规则, eth 命名和默认命名倒叙对应( 如: udev 规则中设置, eth7 对应原本默认 eth0 的 mac 地址, eth0 对应原本 eth7 的 mac 地址)
查看 ip 信息:
查看 dmesg 信息:
可以看到 grub 中不加 net.ifnames=0 biosdevname=0 参数情况下, 配置修改网卡名的 udev 规则, 网卡名从 eth7-0, 没有生效, 还是用预设的命名方式( ensxx)命名。
3)此时规则还是不变, grub 中增加 net.ifnames=0 biosdevname=0 参数
ip 信息如下:
dmesg 信息如下:
网卡名从 ensxx 变成 ethxx 可知 , grub 增加了 net.ifnames=0 biosdevname=0 参数后,预设的重命名规则失效了,但是 8 块网卡, udev 规则里面还是 eth0-7 的话, 还是会用内核默认的命名方式, 此时 udev 规则不生效
4) 如果 udev 规则中, 网卡名从 eth0-7 改成 eth1-8,后, 规则如下:
ip 信息如下:
dmesg 信息如下:
此时可以看到, eth8 由 eth7 重命名而来, eth7 由 eth6 重命名而来, eth6 由eth5 重命名而来, 而 eth5 并不是其他网卡重命名而来, 所以 eth5 丢失。
5) 此时, 我们修改 udev 规则如下:
ip 信息如下:
dmesg 信息如下:
可以看到, eth8 是由 eth0 重命名而来, 因为 eth8 原本不存在, 所以可以从 eth0命名而来, 但是如果/usr/sbin/nameif eth7 00:0c:29:75:54:3c 重命名的话, 由于00:0c:29:75:54:3c 为原本的 eth1( 存在) , eth7 也是存在的, 所以此命名不会成功。 这也就是上面虽然在 /usr/bin/nameif.sh 中加了 8 条重命名的规则, 只有第一条生效的原因。
3. 解决方案
方案一
1) 添加 udev 规则
vim /etc/udev/rules.d/70-persistent-net.rules |
添加如下内容
SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", RUN+="/usr/bin/nameif.sh" |
2) grub 添加参数: biosdevname=0 net.ifnames=0
3) 创建 /usr/bin/nameif.sh 脚本
#!/bin/bash /usr/sbin/nameif eth8 00:0c:29:75:54:32 |
其中 00:0c:29:75:54:32 为默认 eth0 的 mac 地址
方案二
添加 udev 规则
vim /lib/udev/rules.d/70-persistent-net.rules |
添加如下内容:
ACTION=="add", SUBSYSTEM=="net", DRIVERS=="?*", ATTR{address}=="00:0c:29:75:54:32", ATTR{type}=="1", KERNEL=="eth*", NAME="eth8" |
其中 00:0c:29:75:54:32 为默认的 eth0 的 mac 地址, 也就是将 eth0 重命名为eth8
备注
系统启动后, 网卡默认为内核从 eth0 依次向后命令, 然后如果有预设命名规则( grub 界面不加 net.ifnames=0 biosdevname=0 的情况下) , 则配置的 udev 规则不 会 生 效 , 如 果 要 使 udev 规 则 生 效 , 可 以 在 grub 中 加 上 net.ifnames=0 biosdevname=0 参数。
为什么不在 rc.local 加/usr/sbin/nameif eth8 00:0c:29:75:54:32,因为加在 udev 规则里面可以保证可以在网络服务启动之前将网卡命名设置好。
grub 里面加上 net.ifnames=0 biosdevname=0 参数可以禁用预设的命名规则。