Creating a NixOS live CD: Difference between revisions
imported>Onny Add nix flakes example |
m →Static IP Address: Changed networking.interfaces.eth0.ip4 to networking.interfaces.eth0.ipv4.addresses to be consistent with the current proper usage ( as of 24.05 ) |
||
(18 intermediate revisions by 6 users not shown) | |||
Line 1: | Line 1: | ||
== Motivation == | <translate> | ||
== Motivation == <!--T:19--> | |||
<!--T:33--> | |||
Creating a modified NixOS LiveCD out of an existing working NixOS installation has a number of benefits: | Creating a modified NixOS LiveCD out of an existing working NixOS installation has a number of benefits: | ||
<!--T:34--> | |||
* Ensures authenticity. | * Ensures authenticity. | ||
<!--T:35--> | |||
* No need for internet access. | * No need for internet access. | ||
<!--T:36--> | |||
* It is easy to add your own packages and configuration changes to the image. | * It is easy to add your own packages and configuration changes to the image. | ||
== Building == | == Building == <!--T:20--> | ||
Building minimal NixOS installation CD with the <code>nix-build</code> command. In this example with [[Neovim]] preinstalled. | <!--T:37--> | ||
Building minimal NixOS installation CD with the <code>nix-build</code> command by creating this <code>iso.nix</code>-file. In this example with [[Neovim]] preinstalled. | |||
</translate> | |||
<syntaxhighlight lang="nix"> | |||
{ config, pkgs, ... }: | { config, pkgs, ... }: | ||
{ | { | ||
Line 21: | Line 32: | ||
environment.systemPackages = [ pkgs.neovim ]; | environment.systemPackages = [ pkgs.neovim ]; | ||
} | } | ||
</ | </syntaxhighlight> | ||
<translate> | |||
<!--T:21--> | |||
Build the image via: | Build the image via: | ||
</translate> | |||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
nix-build '<nixpkgs/nixos>' -A config.system.build.isoImage -I nixos-config=iso.nix | nix-build '<nixpkgs/nixos>' -A config.system.build.isoImage -I nixos-config=iso.nix | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
<!--T:22--> | |||
Alternatively, use Nix [[Flakes]] to generate a ISO installation image, using the <code>nixos-24.05</code> branch as nixpkgs source: | |||
</translate> | |||
{{file|flake.nix|nix|<nowiki> | {{file|flake.nix|nix|<nowiki> | ||
{ | { | ||
description = " | description = "Minimal NixOS installation media"; | ||
inputs. | inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.05"; | ||
outputs = { self, | outputs = { self, nixpkgs }: { | ||
nixosConfigurations = { | nixosConfigurations = { | ||
exampleIso = | exampleIso = nixpkgs.lib.nixosSystem { | ||
system = "x86_64-linux"; | system = "x86_64-linux"; | ||
modules = [ | modules = [ | ||
({ pkgs, modulesPath, ... }: { | |||
imports = [ (modulesPath + "/installer/cd-dvd/installation-cd-minimal.nix") ]; | |||
environment.systemPackages = [ pkgs.neovim ]; | environment.systemPackages = [ pkgs.neovim ]; | ||
}) | }) | ||
Line 50: | Line 67: | ||
} | } | ||
</nowiki>}} | </nowiki>}} | ||
<translate> | |||
The following commands will generate the iso-image | <!--T:23--> | ||
The following commands will generate the iso-image: | |||
</translate> | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
# git init | # git init | ||
Line 58: | Line 78: | ||
# nix build .#nixosConfigurations.exampleIso.config.system.build.isoImage | # nix build .#nixosConfigurations.exampleIso.config.system.build.isoImage | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
<!--T:24--> | |||
The resulting image can be found in <code>result</code>: | The resulting image can be found in <code>result</code>: | ||
</translate> | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ ls result/iso/ | $ ls result/iso/ | ||
nixos- | nixos-24.05.20240721.63d37cc-x86_64-linux.iso | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
=== Testing the image === | === Testing the image === <!--T:7--> | ||
<!--T:38--> | |||
To inspect the contents of the ISO image: | To inspect the contents of the ISO image: | ||
</translate> | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ mkdir mnt | $ mkdir mnt | ||
Line 77: | Line 103: | ||
$ umount mnt | $ umount mnt | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
<!--T:25--> | |||
To boot the ISO image in an emulator: | To boot the ISO image in an emulator: | ||
</translate> | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ nix-shell -p qemu | $ nix-shell -p qemu | ||
$ qemu-system-x86_64 -enable-kvm -m 256 -cdrom result/iso/nixos-*.iso | $ qemu-system-x86_64 -enable-kvm -m 256 -cdrom result/iso/nixos-*.iso | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
===SSH=== | ===SSH=== <!--T:26--> | ||
<!--T:39--> | |||
In your <tt>iso.nix</tt>: | In your <tt>iso.nix</tt>: | ||
</translate> | |||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
{ | { | ||
Line 99: | Line 132: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
===Static IP Address=== | ===Static IP Address=== <!--T:11--> | ||
<!--T:40--> | |||
Static IP addresses can be set in the image itself. This can be useful for VPS installation. | Static IP addresses can be set in the image itself. This can be useful for VPS installation. | ||
<syntaxhighlight lang="nix"> | </translate> | ||
<syntaxhighlight lang="nix" line="1"> | |||
{ | { | ||
... | ... | ||
networking = { | networking = { | ||
usePredictableInterfaceNames = false; | usePredictableInterfaceNames = false; | ||
interfaces.eth0. | interfaces.eth0.ipv4.addresses = [{ | ||
address = "64.137.201.46"; | address = "64.137.201.46"; | ||
prefixLength = 24; | prefixLength = 24; | ||
Line 119: | Line 155: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
=== Building faster === | === Building faster === <!--T:27--> | ||
<!--T:41--> | |||
The build process is slow because of compression. | The build process is slow because of compression. | ||
<!--T:28--> | |||
Here are some timings for <code>nix-build</code>: | Here are some timings for <code>nix-build</code>: | ||
<!--T:29--> | |||
{| class="wikitable" style="margin:auto" | {| class="wikitable" style="margin:auto" | ||
|+ Compression results | |+ Compression results | ||
Line 139: | Line 180: | ||
|} | |} | ||
<!--T:30--> | |||
See also: [https://gist.github.com/baryluk/70a99b5f26df4671378dd05afef97fce mksquashfs benchmarks] | See also: [https://gist.github.com/baryluk/70a99b5f26df4671378dd05afef97fce mksquashfs benchmarks] | ||
<!--T:31--> | |||
If you don't care about file size, you can use a faster compression | If you don't care about file size, you can use a faster compression | ||
by adding this to your <code>iso.nix</code>: | by adding this to your <code>iso.nix</code>: | ||
</translate> | |||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
{ | { | ||
Line 149: | Line 193: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<translate> | |||
==See also== <!--T:32--> | |||
<!--T:42--> | |||
* [https://nixos.org/manual/nixos/stable/index.html#sec-building-image NixOS Manual: Building a NixOS (Live) ISO]. | * [https://nixos.org/manual/nixos/stable/index.html#sec-building-image NixOS Manual: Building a NixOS (Live) ISO]. | ||
</translate> | |||
[[Category:NixOS]] | [[Category:NixOS]] | ||
[[Category:Deployment]] | [[Category:Deployment]] | ||
[[Category:Cookbook]] | [[Category:Cookbook]] |
Latest revision as of 21:33, 1 August 2024
Motivation
Creating a modified NixOS LiveCD out of an existing working NixOS installation has a number of benefits:
- Ensures authenticity.
- No need for internet access.
- It is easy to add your own packages and configuration changes to the image.
Building
Building minimal NixOS installation CD with the nix-build
command by creating this iso.nix
-file. In this example with Neovim preinstalled.
{ config, pkgs, ... }:
{
imports = [
<nixpkgs/nixos/modules/installer/cd-dvd/installation-cd-minimal.nix>
# Provide an initial copy of the NixOS channel so that the user
# doesn't need to run "nix-channel --update" first.
<nixpkgs/nixos/modules/installer/cd-dvd/channel.nix>
];
environment.systemPackages = [ pkgs.neovim ];
}
Build the image via:
nix-build '<nixpkgs/nixos>' -A config.system.build.isoImage -I nixos-config=iso.nix
Alternatively, use Nix Flakes to generate a ISO installation image, using the nixos-24.05
branch as nixpkgs source:
flake.nix
{
description = "Minimal NixOS installation media";
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.05";
outputs = { self, nixpkgs }: {
nixosConfigurations = {
exampleIso = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [
({ pkgs, modulesPath, ... }: {
imports = [ (modulesPath + "/installer/cd-dvd/installation-cd-minimal.nix") ];
environment.systemPackages = [ pkgs.neovim ];
})
];
};
};
};
}
The following commands will generate the iso-image:
# git init
# git add flake.nix
# nix build .#nixosConfigurations.exampleIso.config.system.build.isoImage
The resulting image can be found in result
:
$ ls result/iso/
nixos-24.05.20240721.63d37cc-x86_64-linux.iso
Testing the image
To inspect the contents of the ISO image:
$ mkdir mnt
$ sudo mount -o loop result/iso/nixos-*.iso mnt
$ ls mnt
boot EFI isolinux nix-store.squashfs version.txt
$ umount mnt
To boot the ISO image in an emulator:
$ nix-shell -p qemu
$ qemu-system-x86_64 -enable-kvm -m 256 -cdrom result/iso/nixos-*.iso
SSH
In your iso.nix:
{
...
# Enable SSH in the boot process.
systemd.services.sshd.wantedBy = pkgs.lib.mkForce [ "multi-user.target" ];
users.users.root.openssh.authorizedKeys.keys = [
"ssh-ed25519 AaAeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee username@host"
];
...
}
Static IP Address
Static IP addresses can be set in the image itself. This can be useful for VPS installation.
{
...
networking = {
usePredictableInterfaceNames = false;
interfaces.eth0.ipv4.addresses = [{
address = "64.137.201.46";
prefixLength = 24;
}];
defaultGateway = "64.137.201.1";
nameservers = [ "8.8.8.8" ];
};
...
}
Building faster
The build process is slow because of compression.
Here are some timings for nix-build
:
squashfsCompression | Time | Size |
---|---|---|
lz4 |
100s | 59% |
gzip -Xcompression-level 1 |
105s | 52% |
gzip |
210s | 49% |
xz -Xdict-size 100% (default) |
450s | 43% |
See also: mksquashfs benchmarks
If you don't care about file size, you can use a faster compression
by adding this to your iso.nix
:
{
isoImage.squashfsCompression = "gzip -Xcompression-level 1";
}