多网卡场景下,Linux实例操作系统的网卡名称发生漂移如何解决?

更新时间:
复制为 MD 格式

本文介绍多网卡场景下,Linux实例操作系统的网卡名称发生漂移的解决办法。

问题现象

如果Linux操作系统中配备了多块网卡,当在运维操作中添加或者删除网卡时,Linux操作系统会出现网卡设备名称与网卡MAC地址对应不一致的情况,也叫网卡漂移。

以eth1实际对应的网卡MAC地址为00:16:3e:10:bd:1b、eth2实际对应的网卡MAC地址为00:16:3e:0c:92:df为例,如果发生了网卡漂移,则执行ip addr命令查看网卡信息时,会在回显中发现eth1对应的网卡MAC地址变为了eth2对应的网卡MAC地址,如下所示。

[root@xxx ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP qlen 1000
    link/ether 00:16:3e:06:0b:f8 brd ff:ff:ff:ff:ff:ff
    inet 172.16.8.52/24 brd 172.16.8.255 scope global eth0
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP qlen 1000
    link/ether 00:16:3e:0c:92:df brd ff:ff:ff:ff:ff:ff
    inet 172.16.8.54/24 brd 172.16.8.255 scope global eth1
4: eth2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP qlen 1000
    link/ether 00:16:3e:10:bd:1b brd ff:ff:ff:ff:ff:ff
    inet 172.16.8.53/24 brd 172.16.8.255 scope global eth2

问题原因

Linux操作系统中网卡相关信息保存在/etc/udev/rules.d/70-persistent-net.rules文件中,当该文件不存在或者文件内容和Linux操作系统实际信息不一致时,就可能导致网卡名称发生漂移。

解决方案

重要
  • 如果您对实例或数据有修改、变更等风险操作,务必注意实例的容灾、容错能力,确保数据安全。建议您提前创建快照,快照相关信息,请参见快照概述

  • 如果您在阿里云平台授权或者提交过登录账号、密码等安全信息,建议您及时修改安全信息。

编辑Linux操作系统中的/etc/udev/rules.d/70-persistent-net.rules文件,在该配置文件中将网卡名称与网卡MAC地址进行绑定,使网卡MAC地址与网卡名称一一对应。

  1. 远程连接ECS实例。
    具体操作,请参见选择ECS远程连接方式
  2. 执行如下命令,进入/etc/udev/rules.d目录。
    cd /etc/udev/rules.d
  3. 执行如下命令,打开/etc/udev/rules.d/70-persistent-net.rules文件。
    vi 70-persistent-net.rules
  4. 执行如下命令,绑定网卡名称与网卡MAC地址。
    SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="MAC地址", KERNEL=="eth*", NAME="网卡名称"
    以绑定eth1对应的MAC地址为00:16:3e:10:bd:1b为例,命令如下:
    SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="00:16:3e:10:bd:1b", KERNEL=="eth*", NAME="eth1"
  5. 执行如下命令,查看/etc/udev/rules.d/70-persistent-net.rules中的网卡配置。
    cat 70-persistent-net.rules
    回显如下:

    [root@xxx xZ ~]# cd /etc/udev/rules.d/
    [root@xxx xZ rules.d]# ls
    60-raw.rules  70-persistent-cd.rules  70-persistent-net.rules  75-persistent-net-generator.rules  99-fuse.rules
    [root@xxx xZ rules.d]# cat 70-persistent-net.rules
    # This file was automatically generated by the /lib/udev/write_net_rules
    # program, run by the persistent-net-generator.rules rules file.
    #
    # You can modify it, as long as you keep each rule on a single
    # line, and change only the value of the NAME= key.
    # elastic network interface
    SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="00:16:3e:10:bd:1b", KERNEL=="eth*", NAME="eth1"
    SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="xxx", KERNEL=="eth*", NAME="eth2"
    SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="xxx", KERNEL=="eth*", NAME="eth0"

    此时,eth1对应的MAC地址为00:16:3e:10:bd:1b,未发生漂移。