Использование предсказуемых имен сетевого интерфейса с альтернативными ядрами

9

Почти постоянно я использую ядра из PPA ядра Ubuntu , или ядра, которые я сам скомпилировал, используя конфигурацию ядра Ubuntu.

Проблема заключается в том, что я использую ядро ​​запаса, которое по умолчанию используется для использования прогнозируемых имен сетевых интерфейсов (т. е. «p4p1»), но когда я использую какое-либо другое ядро, по умолчанию используется старый метод (т.е. «eth0» «).

Несмотря на то, что на этот вопрос не очень важно, у меня был сбой жесткого диска на моем тестовом компьютере, и я делаю новую установку Ubuntu Server 14.04.2.

Я не смог определить, в чем разница между ядрами. Я подозреваю параметр конфигурации ядра, но не смог определить, какой из них.

Мой вопрос: как я могу заставить предсказуемые имена сетевых интерфейсов последовательно работать во всех ядрах?

Дополнительные примечания: Где-то я видел, чтобы отключить предсказуемые имена сетевых интерфейсов, чтобы добавить это к grub:

GRUB_CMDLINE_LINUX_DEFAULT="net.ifnames=0 biosdevname=0"

Итак, я думал, что обратное может помочь:

GRUB_CMDLINE_LINUX_DEFAULT="net.ifnames=1 biosdevname=1"

, но это не имело никакого значения. На самом деле, я никогда не могу заставить не-запасное ядро ​​использовать biosdevname, независимо от настройки. И я никогда не могу заставить ядро ​​для создания файла /etc/udev/rules.d/70-persistent-net.rules (хотя это не то, что я хочу), независимо от настройки net.ifnames . Если у меня есть net.ifnames=1 , то, по крайней мере, не-запасное ядро ​​не создает неверный файл /etc/udev/rules.d/70-persistent-net.rules .

Выдержки из /var/log/udev :
Ядро:

KERNEL[9.216730] add      /devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/p4p1 (net)
ACTION=add
DEVPATH=/devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/p4p1
IFINDEX=2
INTERFACE=p4p1
SEQNUM=1945
SUBSYSTEM=net
...
UDEV  [9.241073] add      /devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/p4p1 (net)
ACTION=add
DEVPATH=/devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/p4p1
ID_BUS=pci
ID_MODEL_FROM_DATABASE=P8P67 and other motherboards
ID_MODEL_ID=0x8168
ID_NET_NAME_MAC=enxf46d04652d8e
ID_NET_NAME_PATH=enp3s0
ID_OUI_FROM_DATABASE=ASUSTek COMPUTER INC.
ID_PCI_CLASS_FROM_DATABASE=Network controller
ID_PCI_SUBCLASS_FROM_DATABASE=Ethernet controller
ID_VENDOR_FROM_DATABASE=Realtek Semiconductor Co., Ltd.
ID_VENDOR_ID=0x10ec
IFINDEX=2
INTERFACE=p4p1

От ядра Ubuntu PPA 4.1RC5:

KERNEL[10.772566] add      /devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/eth0 (net)
ACTION=add
DEVPATH=/devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/eth0
IFINDEX=2
INTERFACE=eth0
SEQNUM=1962
SUBSYSTEM=net
...
UDEV  [11.185866] add      /devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/eth0 (net)
ACTION=add
DEVPATH=/devices/pci0000:00/0000:00:1c.4/0000:03:00.0/net/eth0
ID_BUS=pci
ID_MODEL_FROM_DATABASE=P8P67 and other motherboards
ID_MODEL_ID=0x8168
ID_NET_NAME_MAC=enxf46d04652d8e
ID_NET_NAME_PATH=enp3s0
ID_OUI_FROM_DATABASE=ASUSTek COMPUTER INC.
ID_PCI_CLASS_FROM_DATABASE=Network controller
ID_PCI_SUBCLASS_FROM_DATABASE=Ethernet controller
ID_VENDOR_FROM_DATABASE=Realtek Semiconductor Co., Ltd.
ID_VENDOR_ID=0x10ec
IFINDEX=2
INTERFACE=eth0
SEQNUM=1962
SUBSYSTEM=net
USEC_INITIALIZED=3227

Примечание. Я временно перешел от этой проблемы, разрешив создать файл /etc/udev/rules.d/70-persistent-net.rules и затем отредактировать его для правильных имен устройств. В конечном счете, я хотел бы избавиться от файла.

    
задан Doug Smythies 25.05.2015 в 23:56
источник

2 ответа

26

Вам нужно различать 3 вещи:

  • Предсказуемые имена интерфейсов
  • biosdevname
  • 70-persistent.rules правило udev

Вы либо решили использовать одно из этих решений , но одновременно не используете 2 или 3. (На самом деле вы можете, но один из них будет иметь приоритет и замаскировать другое (-ы))

Хорошим введением в текущую ситуацию является сообщение в списке рассылки ubuntu dev

Предсказуемые имена интерфейсов

Предсказуемые имена интерфейсов - это udevd , поскольку v197 сгенерирован в /lib/udev/rules.d/80-net-setup-link.rules

systemd использует по умолчанию новое предсказуемое имя интерфейса. Однако , если только upstream systemd, в Ubuntu, вам нужно отказаться от использования net.ifnames=1

Он не имеет значения для версии ядра . Но вам нужно использовать командную строку ядра, чтобы настроить ее, изменив конфигурацию grub /etc/default/grub , например:

GRUB_CMDLINE_LINUX_DEFAULT="net.ifnames=1"

и запустите

sudo update-grub

В 14.04 или 14.10 без systemd должно быть достаточно удалить 70-persitent-net.rules, как описано ниже в примечании.

Biosdevname

biosdevname представляет собой попытку dell решить аналогичную проблему, чем предсказуемое имя интерфейса в systemd. Он используется по умолчанию на сервере ubuntu . Вы можете получить его, установив пакет biosdevname

sudo apt-get install biosdevname

Примечание

Вы можете отключить его, используя командную строку ядра в config grub:

GRUB_CMDLINE_LINUX_DEFAULT="biosdevname=0"

и запустите

sudo update-grub

или просто удалите пакет.

sudo apt-get purge biosdevname
sudo update-initramfs -u

правила udev

Это значение по умолчанию на рабочем столе Ubuntu . Правило udev /lib/udev/rules.d/75-persistent-net-generator.rules создает во время первой загрузки пользовательские правила /etc/udev/rules.d/70-persistent-net.rules с MAC-адресом вашего интерфейса, чтобы получить постоянное имя для вашего интерфейса.

Примечание

Если вы уже используете правила udev, вам нужно удалить /etc/udev/rules.d/70-persistent-net.rules и избежать его регенерации при каждой загрузке, которую вам нужно запустить

sudo ln -s /dev/null /etc/udev/rules.d/75-persistent-net-generator.rules

После этого, если вы используете systemd , вам необходимо выбрать имя прогнозируемого интерфейса, как описано выше.

    
ответ дан solsTiCe 26.05.2015 в 15:14
источник
3
  1. В Ubuntu Server 16.04LTS все, что я сделал, было запущено:

    ln -s /dev/null /etc/udev/rules.d/80-net-setup-link.rules
    
  2. Затем создайте файл, используя

    sudo vi /etc/systemd/network/10-internet.link
    

    и добавьте следующее

    [Match]
    Path=pci-0000:(your device mac address)
    
    [Link]
    Name=eth0 (or whatever you want to name it)
    

    :wq для сохранения файла

  3. затем перезагрузите и настройте файл /etc/network/interfaces .. затем перезагрузитесь снова

Надеюсь, что это поможет кому-то

    
ответ дан Jadey1412 04.10.2016 в 00:36