about summary refs log tree commit diff
path: root/nixpkgs/nixos/doc/manual/from_md/installation/installing-kexec.section.xml
blob: 46ea0d59b6c302ea74add06663ef441f547943f2 (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
<section xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xml:id="sec-booting-via-kexec">
  <title><quote>Booting</quote> into NixOS via kexec</title>
  <para>
    In some cases, your system might already be booted into/preinstalled
    with another Linux distribution, and booting NixOS by attaching an
    installation image is quite a manual process.
  </para>
  <para>
    This is particularly useful for (cloud) providers where you can’t
    boot a custom image, but get some Debian or Ubuntu installation.
  </para>
  <para>
    In these cases, it might be easier to use <literal>kexec</literal>
    to <quote>jump into NixOS</quote> from the running system, which
    only assumes <literal>bash</literal> and <literal>kexec</literal> to
    be installed on the machine.
  </para>
  <para>
    Note that kexec may not work correctly on some hardware, as devices
    are not fully re-initialized in the process. In practice, this
    however is rarely the case.
  </para>
  <para>
    To build the necessary files from your current version of nixpkgs,
    you can run:
  </para>
  <programlisting>
nix-build -A kexec.x86_64-linux '&lt;nixpkgs/nixos/release.nix&gt;'
</programlisting>
  <para>
    This will create a <literal>result</literal> directory containing
    the following:
  </para>
  <itemizedlist spacing="compact">
    <listitem>
      <para>
        <literal>bzImage</literal> (the Linux kernel)
      </para>
    </listitem>
    <listitem>
      <para>
        <literal>initrd</literal> (the initrd file)
      </para>
    </listitem>
    <listitem>
      <para>
        <literal>kexec-boot</literal> (a shellscript invoking
        <literal>kexec</literal>)
      </para>
    </listitem>
  </itemizedlist>
  <para>
    These three files are meant to be copied over to the other already
    running Linux Distribution.
  </para>
  <para>
    Note it’s symlinks pointing elsewhere, so <literal>cd</literal> in,
    and use <literal>scp * root@$destination</literal> to copy it over,
    rather than rsync.
  </para>
  <para>
    Once you finished copying, execute <literal>kexec-boot</literal>
    <emphasis>on the destination</emphasis>, and after some seconds, the
    machine should be booting into an (ephemeral) NixOS installation
    medium.
  </para>
  <para>
    In case you want to describe your own system closure to kexec into,
    instead of the default installer image, you can build your own
    <literal>configuration.nix</literal>:
  </para>
  <programlisting language="bash">
{ modulesPath, ... }: {
  imports = [
    (modulesPath + &quot;/installer/netboot/netboot-minimal.nix&quot;)
  ];

  services.openssh.enable = true;
  users.users.root.openssh.authorizedKeys.keys = [
    &quot;my-ssh-pubkey&quot;
  ];
}
</programlisting>
  <programlisting>
nix-build '&lt;nixpkgs/nixos&gt;' \
  --arg configuration ./configuration.nix
  --attr config.system.build.kexecTree
</programlisting>
  <para>
    Make sure your <literal>configuration.nix</literal> does still
    import <literal>netboot-minimal.nix</literal> (or
    <literal>netboot-base.nix</literal>).
  </para>
</section>