(add limitations section) |
(works on more systems now) |
||
Line 22: | Line 22: | ||
* add biosdevname to @base (complete 28-Nov-2010) | * add biosdevname to @base (complete 28-Nov-2010) | ||
* add biosdevname to dracut-network (https://bugzilla.redhat.com/show_bug.cgi?id=659915) | * add biosdevname to dracut-network (https://bugzilla.redhat.com/show_bug.cgi?id=659915) | ||
* have NetworkManager display the label somehow (TBD, not critical for feature) | |||
== Benefit to Fedora == | == Benefit to Fedora == | ||
System Administrators can then use BIOS-provided names, which are consistent and not arbitrarily named, for their network ports. This eliminates the confusion that non-deterministic naming brings, and eliminates the use of hard-coded MAC address based port renaming which a) is racy and error-prone, and b) introduces state into an otherwise stateless system. | System Administrators can then use BIOS-provided names, which are consistent and not arbitrarily named, for their network ports. This eliminates the confusion that non-deterministic naming brings, and eliminates the use of hard-coded MAC address based port renaming which a) is racy and error-prone, and b) introduces state into an otherwise stateless system. | ||
This | This change affects most desktop, notebook, and server-class systems. | ||
== Limitations == | == Limitations == | ||
Line 35: | Line 36: | ||
== How To Test == | == How To Test == | ||
* System-Under-Test | * System-Under-Test can be just about any system. Systems that expose SMBIOS 2.6 Type 9 and Type 41 fields are preferred, but the code will work on systems that expose the legacy PCI IRQ Routing Table as well. | ||
* biosdevname must be installed on the target system. | * biosdevname must be installed on the target system. | ||
* erase /etc/udev/rules.d/70-persistent-net.rules file. This is where naming is persisted across reboots. | * erase /etc/udev/rules.d/70-persistent-net.rules file. This is where naming is persisted across reboots. | ||
Line 63: | Line 64: | ||
By changing the naming convention, system administrators will no longer have to guess at the ethX to physical port mapping, or invoke workarounds on each system to rename them into some "sane" order. | By changing the naming convention, system administrators will no longer have to guess at the ethX to physical port mapping, or invoke workarounds on each system to rename them into some "sane" order. | ||
This feature affects all systems that expose network port naming information in SMBIOS 2.6 or later (specifically field types 9 and 41). Dell PowerEdge 10G and newer servers (PowerEdge 1950 III family, PowerEdge R710 family, and newer), and HP ProLiant G6 servers and newer are known to expose this information, as do some newer desktop models. | This feature affects all systems that expose network port naming information in SMBIOS 2.6 or later (specifically field types 9 and 41). Dell PowerEdge 10G and newer servers (PowerEdge 1950 III family, PowerEdge R710 family, and newer), and HP ProLiant G6 servers and newer are known to expose this information, as do some newer desktop models. Furthermore, most older systems expose some information in the PCI IRQ Routing Table, which will be consulted if information is not provided by SMBIOS. | ||
Existing installations upgraded to Fedora 15 will not see a change in names unless /lib/udev/rules.d/70-persistent-net.rules is deleted and the HWADDR lines are removed from all /etc/sysconfig/network-scripts/ifcfg-* files. | Existing installations upgraded to Fedora 15 will not see a change in names unless /lib/udev/rules.d/70-persistent-net.rules is deleted and the HWADDR lines are removed from all /etc/sysconfig/network-scripts/ifcfg-* files. |
Revision as of 21:56, 9 December 2010
Consistent Network Device Naming
Summary
On Dell and HP servers with multiple network ports on the motherboard, name them lomX rather than ethX.
Owner
- Name: Matt Domsch
- Email: Matt_Domsch@dell.com
Current status
- Targeted release: Fedora 15
- Last updated: 2010-12-03
- Percentage of completion: 90%
Detailed Description
Systems, particularly servers, with multiple network ports, name the ports ethX in a non-deterministic order, and are therefore not useful for system administrators.
The proposal is as follows:
- update biosdevname to upstream release 0.3.1 (complete 27-Nov-2010)
- ensure postinstall udev uses biosdevname in udev rules to name LAN-on-Motherboard network ports from ethX to em[1234] and PCI cards to pci<slot>#<port>_<vf> (complete 27-Nov-2010)
- have kickstart / anaconda use the biosdevname-provided name em[1234] (complete 28-Nov-2010)
- add biosdevname to @base (complete 28-Nov-2010)
- add biosdevname to dracut-network (https://bugzilla.redhat.com/show_bug.cgi?id=659915)
- have NetworkManager display the label somehow (TBD, not critical for feature)
Benefit to Fedora
System Administrators can then use BIOS-provided names, which are consistent and not arbitrarily named, for their network ports. This eliminates the confusion that non-deterministic naming brings, and eliminates the use of hard-coded MAC address based port renaming which a) is racy and error-prone, and b) introduces state into an otherwise stateless system.
This change affects most desktop, notebook, and server-class systems.
Limitations
Not all add-in cards have a method to expose their Linux interface name(s) to external port mapping. biosdevname may provide incorrect names for such. Discussions are ongoing on the netdev mailing list to standardize a method of exposing such mapping.
Scope
- See above
How To Test
- System-Under-Test can be just about any system. Systems that expose SMBIOS 2.6 Type 9 and Type 41 fields are preferred, but the code will work on systems that expose the legacy PCI IRQ Routing Table as well.
- biosdevname must be installed on the target system.
- erase /etc/udev/rules.d/70-persistent-net.rules file. This is where naming is persisted across reboots.
- reboot the system
- Following reboot:
- /sbin/ifconfig -a must show LAN-on-Motherboard ports named em[1234]
- em[1234] must correspond to the chassis labels. Verify using ethtool -p em[1234] and watch the lights blink.
- Installing using Anaconda:
- anaconda should present network devices to use, having the new naming convention.
User Experience
Ethernet NICs embedded on the motherboard will be named em[1234] rather than ethX. PCI add-in card NICs will be named pci<slot>#<port>_<vf>
Dependencies
None
Contingency Plan
None necessary, revert to previous release behaviour.
Documentation
Release Notes
- Servers often have multiple Ethernet ports, either embedded on the motherboard, or on add-in PCI cards. Linux has traditionally named these ports ethX, but there has been no correlation of the ethX names to the chassis labels - the ethX names are non-deterministic. Starting in Fedora 15, Ethernet ports on servers will have a new naming scheme corresponding to physical locations, rather than ethX. Ethernet ports embedded on server motherboards will be named em<port_number>, while ports on PCI cards will be named pci<slot_number>#<port_number>, corresponding to the chassis labels. Additionally, if the network device is an SR-IOV Virtual Function, the name will have a suffix of _<virtual_instance>.
By changing the naming convention, system administrators will no longer have to guess at the ethX to physical port mapping, or invoke workarounds on each system to rename them into some "sane" order.
This feature affects all systems that expose network port naming information in SMBIOS 2.6 or later (specifically field types 9 and 41). Dell PowerEdge 10G and newer servers (PowerEdge 1950 III family, PowerEdge R710 family, and newer), and HP ProLiant G6 servers and newer are known to expose this information, as do some newer desktop models. Furthermore, most older systems expose some information in the PCI IRQ Routing Table, which will be consulted if information is not provided by SMBIOS.
Existing installations upgraded to Fedora 15 will not see a change in names unless /lib/udev/rules.d/70-persistent-net.rules is deleted and the HWADDR lines are removed from all /etc/sysconfig/network-scripts/ifcfg-* files.