summary refs log tree commit diff
path: root/nixos/doc/manual/development/building-parts.xml
blob: eaffc0ef47c2f0af4b809ec5ce4761a3d9098788 (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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<chapter 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-building-parts">
 <title>Building Specific Parts of NixOS</title>
 <para>
  With the command <command>nix-build</command>, you can build specific parts
  of your NixOS configuration. This is done as follows:
<screen>
$ cd <replaceable>/path/to/nixpkgs/nixos</replaceable>
$ nix-build -A config.<replaceable>option</replaceable></screen>
  where <replaceable>option</replaceable> is a NixOS option with type
  “derivation” (i.e. something that can be built). Attributes of interest
  include:
  <variablelist>
   <varlistentry>
    <term>
     <varname>system.build.toplevel</varname>
    </term>
    <listitem>
     <para>
      The top-level option that builds the entire NixOS system. Everything else
      in your configuration is indirectly pulled in by this option. This is
      what <command>nixos-rebuild</command> builds and what
      <filename>/run/current-system</filename> points to afterwards.
     </para>
     <para>
      A shortcut to build this is:
<screen>
$ nix-build -A system</screen>
     </para>
    </listitem>
   </varlistentry>
   <varlistentry>
    <term>
     <varname>system.build.manual.manual</varname>
    </term>
    <listitem>
     <para>
      The NixOS manual.
     </para>
    </listitem>
   </varlistentry>
   <varlistentry>
    <term>
     <varname>system.build.etc</varname>
    </term>
    <listitem>
     <para>
      A tree of symlinks that form the static parts of
      <filename>/etc</filename>.
     </para>
    </listitem>
   </varlistentry>
   <varlistentry>
    <term>
     <varname>system.build.initialRamdisk</varname>
    </term>
    <term>
     <varname>system.build.kernel</varname>
    </term>
    <listitem>
     <para>
      The initial ramdisk and kernel of the system. This allows a quick way to
      test whether the kernel and the initial ramdisk boot correctly, by using
      QEMU’s <option>-kernel</option> and <option>-initrd</option> options:
<screen>
$ nix-build -A config.system.build.initialRamdisk -o initrd
$ nix-build -A config.system.build.kernel -o kernel
$ qemu-system-x86_64 -kernel ./kernel/bzImage -initrd ./initrd/initrd -hda /dev/null
</screen>
     </para>
    </listitem>
   </varlistentry>
   <varlistentry>
    <term>
     <varname>system.build.nixos-rebuild</varname>
    </term>
    <term>
     <varname>system.build.nixos-install</varname>
    </term>
    <term>
     <varname>system.build.nixos-generate-config</varname>
    </term>
    <listitem>
     <para>
      These build the corresponding NixOS commands.
     </para>
    </listitem>
   </varlistentry>
   <varlistentry>
    <term>
     <varname>systemd.units.<replaceable>unit-name</replaceable>.unit</varname>
    </term>
    <listitem>
     <para>
      This builds the unit with the specified name. Note that since unit names
      contain dots (e.g. <literal>httpd.service</literal>), you need to put
      them between quotes, like this:
<screen>
$ nix-build -A 'config.systemd.units."httpd.service".unit'
</screen>
      You can also test individual units, without rebuilding the whole system,
      by putting them in <filename>/run/systemd/system</filename>:
<screen>
$ cp $(nix-build -A 'config.systemd.units."httpd.service".unit')/httpd.service \
    /run/systemd/system/tmp-httpd.service
# systemctl daemon-reload
# systemctl start tmp-httpd.service
</screen>
      Note that the unit must not have the same name as any unit in
      <filename>/etc/systemd/system</filename> since those take precedence over
      <filename>/run/systemd/system</filename>. That’s why the unit is
      installed as <filename>tmp-httpd.service</filename> here.
     </para>
    </listitem>
   </varlistentry>
  </variablelist>
 </para>
</chapter>