2014-08-24 18:18:18 +01:00
<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">
2018-05-02 00:57:09 +01:00
<title > Building Specific Parts of NixOS</title>
<para >
2019-09-18 21:13:35 +01:00
With the command <command > nix-build</command> , you can build specific parts of your NixOS configuration. This is done as follows:
2014-08-24 18:18:18 +01:00
<screen >
2019-06-17 12:25:50 +01:00
<prompt > $ </prompt> cd <replaceable > /path/to/nixpkgs/nixos</replaceable>
<prompt > $ </prompt> nix-build -A config.<replaceable > option</replaceable> </screen>
2019-09-18 21:13:35 +01:00
where <replaceable > option</replaceable> is a NixOS option with type “derivation” (i.e. something that can be built). Attributes of interest include:
2018-05-02 00:57:09 +01:00
<variablelist >
<varlistentry >
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.toplevel</varname>
2018-05-02 00:57:09 +01:00
</term>
2014-08-24 18:18:18 +01:00
<listitem >
2018-05-02 00:57:09 +01:00
<para >
2019-09-18 21:13:35 +01:00
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.
2018-05-02 00:57:09 +01:00
</para>
<para >
A shortcut to build this is:
2014-08-24 18:18:18 +01:00
<screen >
2019-06-17 12:25:50 +01:00
<prompt > $ </prompt> nix-build -A system</screen>
2018-05-02 00:57:09 +01:00
</para>
2014-08-24 18:18:18 +01:00
</listitem>
2018-05-02 00:57:09 +01:00
</varlistentry>
<varlistentry >
2018-06-01 02:03:51 +01:00
<term >
2018-09-06 20:17:44 +01:00
<varname > system.build.manual.manualHTML</varname>
2018-05-02 00:57:09 +01:00
</term>
2014-08-24 18:18:18 +01:00
<listitem >
2018-05-02 00:57:09 +01:00
<para >
The NixOS manual.
</para>
</listitem>
</varlistentry>
<varlistentry >
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.etc</varname>
2018-05-02 00:57:09 +01:00
</term>
<listitem >
<para >
2019-09-18 21:13:35 +01:00
A tree of symlinks that form the static parts of <filename > /etc</filename> .
2018-05-02 00:57:09 +01:00
</para>
</listitem>
</varlistentry>
<varlistentry >
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.initialRamdisk</varname>
2018-05-02 00:57:09 +01:00
</term>
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.kernel</varname>
2018-05-02 00:57:09 +01:00
</term>
<listitem >
<para >
2019-09-18 21:13:35 +01:00
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:
2014-08-24 18:18:18 +01:00
<screen >
2019-06-17 12:25:50 +01:00
<prompt > $ </prompt> nix-build -A config.system.build.initialRamdisk -o initrd
<prompt > $ </prompt> nix-build -A config.system.build.kernel -o kernel
<prompt > $ </prompt> qemu-system-x86_64 -kernel ./kernel/bzImage -initrd ./initrd/initrd -hda /dev/null
2014-08-24 18:18:18 +01:00
</screen>
2018-05-02 00:57:09 +01:00
</para>
2014-08-24 18:18:18 +01:00
</listitem>
2018-05-02 00:57:09 +01:00
</varlistentry>
<varlistentry >
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.nixos-rebuild</varname>
2018-05-02 00:57:09 +01:00
</term>
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.nixos-install</varname>
2018-05-02 00:57:09 +01:00
</term>
2018-06-01 02:03:51 +01:00
<term >
<varname > system.build.nixos-generate-config</varname>
2018-05-02 00:57:09 +01:00
</term>
2014-08-24 18:18:18 +01:00
<listitem >
2018-05-02 00:57:09 +01:00
<para >
These build the corresponding NixOS commands.
</para>
2014-08-24 18:18:18 +01:00
</listitem>
2018-05-02 00:57:09 +01:00
</varlistentry>
<varlistentry >
2018-06-01 02:03:51 +01:00
<term >
<varname > systemd.units.<replaceable > unit-name</replaceable> .unit</varname>
2018-05-02 00:57:09 +01:00
</term>
2014-08-24 18:18:18 +01:00
<listitem >
2018-05-02 00:57:09 +01:00
<para >
2019-09-18 21:13:35 +01:00
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:
2014-08-24 18:18:18 +01:00
<screen >
2019-06-17 12:25:50 +01:00
<prompt > $ </prompt> nix-build -A 'config.systemd.units."httpd.service".unit'
2014-08-24 18:18:18 +01:00
</screen>
2019-09-18 21:13:35 +01:00
You can also test individual units, without rebuilding the whole system, by putting them in <filename > /run/systemd/system</filename> :
2014-08-24 18:18:18 +01:00
<screen >
2019-06-17 12:25:50 +01:00
<prompt > $ </prompt> cp $(nix-build -A 'config.systemd.units."httpd.service".unit')/httpd.service \
2014-08-24 18:18:18 +01:00
/run/systemd/system/tmp-httpd.service
2019-06-17 12:25:50 +01:00
<prompt > # </prompt> systemctl daemon-reload
<prompt > # </prompt> systemctl start tmp-httpd.service
2014-08-24 18:18:18 +01:00
</screen>
2019-09-18 21:13:35 +01:00
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.
2018-05-02 00:57:09 +01:00
</para>
2014-08-24 18:18:18 +01:00
</listitem>
2018-05-02 00:57:09 +01:00
</varlistentry>
</variablelist>
</para>
2016-06-01 15:23:32 +01:00
</chapter>