ifrename - rename network interfaces based on various static criteria
ifrename [-c configfile] [-p] [-d] [-u] [-v] [-V] [-D] [-C]
ifrename [-c configfile] [-i interface] [-n newname]
is a tool allowing you to assign a consistent name to each of
your network interface.
By default, interface names are dynamic, and each network interface is assigned
the first available name (eth0
...). The order network
interfaces are created may vary. For built-in interfaces, the kernel boot time
enumeration may vary. For removable interface, the user may plug them in any
allow the user to decide what name a network interface will
can use a variety of selectors
to specify how
interface names match the network interfaces on the system, the most common
selector is the interface MAC address
must be run before interfaces are brought up, which is why it's
mostly useful in various scripts (init, hotplug) but is seldom used directly
by the user. By default, ifrename
renames all present system interfaces
using mappings defined in /etc/iftab
- -c configfile
- Set the configuration file to be used (by default
/etc/iftab). The configuration file define the mapping between
selectors and interface names, and is described in iftab(5).
If configfile is "-", the configuration is read from
- Probe (load) kernel modules before renaming interfaces. By
default ifrename only check interfaces already loaded, and doesn't
auto-load the required kernel modules. This option enables smooth
integration with system not loading modules before calling
- Enable various Debian specific hacks. Combined with
-p, only modules for interfaces specified in
/etc/network/interface are loaded.
- -i interface
- Only rename the specified interface as opposed to
all interfaces on the system. The new interface name is printed.
- -n newname
- When used with -i, specify the new name of the
interface. The list of mappings from the configuration file is bypassed,
the interface specified with -i is renamed directly to
newname. The new name may be a wildcard containing a single '*'.
When used without -i, rename interfaces by using only mappings that
would rename them to newname. The new name may not be a wildcard.
This use of ifrename is discouraged, because inefficient (-n
without -i). All the interfaces of the system need to be processed
at each invocation, therefore in most case it is not faster than just
letting ifrename renaming all of them (without both -n and
- Enable name takeover support. This allow interface name
swapping between two or more interfaces.
Takeover enable an interface to 'steal' the name of another interface. This
works only with kernel 2.6.X and if the other interface is down.
Consequently, this is not compatible with Hotplug. The other interface is
assigned a random name, but may be renamed later with 'ifrename'.
The number of takeovers is limited to avoid circular loops, and therefore
some complex multi-way name swapping situations may not be fully
In any case, name swapping and the use of this feature is discouraged, and
you are invited to choose unique and unambiguous names for your
- Enable udev output mode. This enables proper
integration of ifrename in the udev framework,
udevd(8) will use ifrename to assign interface names present
in /etc/iftab. In this mode the output of ifrename can be parsed
directly by udevd(8) as an IMPORT action. This requires udev
version 107 or later.
- Dry-run mode. Ifrename won't change any interface, it will
only print new interface name, if applicable, and return.
In dry-run mode, interface name wildcards are not resolved. New interface
name is printed, even if it is the same as the old name.
Be also aware that some selectors can only be read by root, for example
those based on ethtool), and will fail silently if run by a normal
user. In other words, dry-run mode under a standard user may not give the
- Verbose mode. Ifrename will display internal results of
parsing its configuration file and querying the interfaces selectors.
Combined with the dry-run option, this is a good way to debug
complex configurations or trivial problems.
- Count matching interfaces. Display the number of interface
matched, and return it as the exit status of ifrename.
The number of interfaces matched is the number of interface on the system
for which a mapping was found in the config file (which is different from
the number of interface renamed).
Jean Tourrilhes - firstname.lastname@example.org