summary refs log tree commit diff
path: root/nixos/doc/manual/configuration/renaming-interfaces.xml
blob: d760bb3a4dace31d68a03cb5fcee760046f3a957 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<section xmlns="http://docbook.org/ns/docbook"
         xmlns:xlink="http://www.w3.org/1999/xlink"
         xmlns:xi="http://www.w3.org/2001/XInclude"
         version="5.0"
         xml:id="sec-rename-ifs">
 <title>Renaming network interfaces</title>

 <para>
  NixOS uses the udev
  <link xlink:href="https://systemd.io/PREDICTABLE_INTERFACE_NAMES/">predictable naming scheme</link>
  to assign names to network interfaces. This means that by default
  cards are not given the traditional names like
  <literal>eth0</literal> or <literal>eth1</literal>, whose order can
  change unpredictably across reboots. Instead, relying on physical
  locations and firmware information, the scheme produces names like
  <literal>ens1</literal>, <literal>enp2s0</literal>, etc.
 </para>

 <para>
  These names are predictable but less memorable and not necessarily
  stable: for example installing new hardware or changing firmware
  settings can result in a
  <link xlink:href="https://github.com/systemd/systemd/issues/3715#issue-165347602">name change</link>.
  If this is undesirable, for example if you have a single ethernet
  card, you can revert to the traditional scheme by setting
  <xref linkend="opt-networking.usePredictableInterfaceNames"/> to
  <literal>false</literal>.
 </para>

 <section xml:id="sec-custom-ifnames">
  <title>Assigning custom names</title>
  <para>
   In case there are multiple interfaces of the same type, it’s better to
   assign custom names based on the device hardware address. For
   example, we assign the name <literal>wan</literal> to the interface
   with MAC address <literal>52:54:00:12:01:01</literal> using a
   netword link unit:
  </para>
  <programlisting>
 <link linkend="opt-systemd.network.links">systemd.network.links."10-wan"</link> = {
   matchConfig.MACAddress = "52:54:00:12:01:01";
   linkConfig.Name = "wan";
 };
  </programlisting>
  <para>
   Note that links are directly read by udev, <emphasis>not networkd</emphasis>,
   and will work even if networkd is disabled.
  </para>
  <para>
   Alternatively, we can use a plain old udev rule:
  </para>
  <programlisting>
 <link linkend="opt-services.udev.initrdRules">services.udev.initrdRules</link> = ''
  SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", \
  ATTR{address}=="52:54:00:12:01:01", KERNEL=="eth*", NAME="wan"
 '';
  </programlisting>

  <warning><para>
   The rule must be installed in the initrd using
   <literal>services.udev.initrdRules</literal>, not the usual
   <literal>services.udev.extraRules</literal> option. This is to avoid race
   conditions with other programs controlling the interface.
  </para></warning>
 </section>

</section>