【案例实操】银河麒麟桌面操作系统实例分享,V10SP1重启后网卡错乱解决方法

更多银河麒麟操作系统产品及技术讨论,欢迎加入银河麒麟操作系统官方论坛

https://forum.kylinos.cn


了解更多银河麒麟操作系统全新产品,请点击访问

麒麟软件产品专区:https://product.kylinos.cn

开发者专区:https://developer.kylinos.cn

文档中心:https://document.kylinos.cn


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 参数可以禁用预设的命名规则。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值