Creating a NixOS live CD/ru: Difference between revisions
No edit summary |
Replaced content with "== Мотивация ==" |
||
(18 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
<span id="Motivation"></span> | |||
== Мотивация == | == Мотивация == | ||
* | Создвние модифицированного образа NixOS из имеюшийся системы имеет множество преимуществ: | ||
* Нет необходимости в доступе | |||
* | <div lang="en" dir="ltr" class="mw-content-ltr"> | ||
* Ensures authenticity. | |||
</div> | |||
* Нет необходимости в интернет доступе. | |||
* В собстенный образ легко добавить пакеты и изменять конфигурацию. | |||
<span id="Building"></span> | |||
== Сборка == | |||
<div lang="en" dir="ltr" class="mw-content-ltr"> | <div lang="en" dir="ltr" class="mw-content-ltr"> | ||
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. | 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. | ||
</div> | </div> | ||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
{ config, pkgs, ... }: | { config, pkgs, ... }: | ||
Line 21: | Line 32: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Сборка образа с помощью: | Сборка образа с помощью: | ||
<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> | ||
В качестве альтернативы используйте Nix [[Flakes]] для создания установочного образа ISO, используя ветку <code>nixos-24.05</code> в качестве источника nixpkgs: | |||
{{file|flake.nix|nix|<nowiki> | {{file|flake.nix|nix|<nowiki> | ||
{ | { | ||
Line 47: | Line 60: | ||
} | } | ||
</nowiki>}} | </nowiki>}} | ||
Следующие команды создадут ISO-образ: | Следующие команды создадут ISO-образ: | ||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
# git init | # git init | ||
Line 53: | Line 68: | ||
# nix build .#nixosConfigurations.exampleIso.config.system.build.isoImage | # nix build .#nixosConfigurations.exampleIso.config.system.build.isoImage | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Готовый образ может быть найден а <code>result</code>: | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ ls result/iso/ | $ ls result/iso/ | ||
nixos-24.05.20240721.63d37cc-x86_64-linux.iso | nixos-24.05.20240721.63d37cc-x86_64-linux.iso | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<span id="Testing_the_image"></span> | |||
=== Тестирование образа === | === Тестирование образа === | ||
Чтобы просмотреть содержимое образа ISO, выполните следующие действия: | Чтобы просмотреть содержимое образа ISO, выполните следующие действия: | ||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
To inspect the contents of the ISO image: | |||
</div> | |||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ mkdir mnt | $ mkdir mnt | ||
Line 69: | Line 91: | ||
$ umount mnt | $ umount mnt | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Чтобы загрузить образ ISO в эмуляторе: | Чтобы загрузить образ ISO в эмуляторе: | ||
<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> | ||
<span id="SSH"></span> | |||
===SSH=== | ===SSH=== | ||
В вашем <tt>iso.nix</tt>: | В вашем <tt>iso.nix</tt>: | ||
В вашем <tt>iso.nix</tt> | |||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
{ | { | ||
Line 87: | Line 116: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<span id="Static_IP_Address"></span> | |||
=== Статический IP-адрес === | === Статический IP-адрес === | ||
Статические IP-адреса можно задать в самом образе. Это может быть полезно при установке VPS. | Статические IP-адреса можно задать в самом образе. Это может быть полезно при установке VPS. | ||
Статический IP-адрес может бвть установлен в образе. Это может быть полехно для установки на VPS. | |||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
{ | { | ||
Line 104: | Line 138: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<span id="Building_faster"></span> | |||
=== Ускорение сборки === | === Ускорение сборки === | ||
Процесс сборки может быть медленным из-за сжатия. | Процесс сборки может быть медленным из-за сжатия. | ||
Процессс сборки медленный из-за сжатия. | |||
Вот некоторые значения времени для <code>nix-build</code>: | Вот некоторые значения времени для <code>nix-build</code>: | ||
{| class="wikitable" style="margin:auto" | {| class="wikitable" style="margin:auto" | ||
|+ Результаты сжатия | |+ Результаты сжатия | ||
Line 121: | Line 160: | ||
| <code>xz -Xdict-size 100%</code> (По умолчанию) || 450s || 43% | | <code>xz -Xdict-size 100%</code> (По умолчанию) || 450s || 43% | ||
|} | |} | ||
<div lang="en" dir="ltr" class="mw-content-ltr"> | <div lang="en" dir="ltr" class="mw-content-ltr"> | ||
See also: [https://gist.github.com/baryluk/70a99b5f26df4671378dd05afef97fce mksquashfs benchmarks] | See also: [https://gist.github.com/baryluk/70a99b5f26df4671378dd05afef97fce mksquashfs benchmarks] | ||
Line 126: | Line 166: | ||
Если вам не важен размер файла, вы можете использовать более быстрое сжатие, добавив этот параметр к вашему <code>iso.nix</code>: | Если вам не важен размер файла, вы можете использовать более быстрое сжатие, добавив этот параметр к вашему <code>iso.nix</code>: | ||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
{ | { | ||
Line 131: | Line 172: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<span id="See_also"></span> | |||
==См. Также== | ==См. Также== | ||
* [https://nixos.org/manual/nixos/stable/index.html#sec-building-image NixOS Manual: Сборка Live-образа NixOS]. | * [https://nixos.org/manual/nixos/stable/index.html#sec-building-image NixOS Manual: Сборка Live-образа NixOS]. | ||
<div lang="en" dir="ltr" class="mw-content-ltr"> | |||
* [https://nixos.org/manual/nixos/stable/index.html#sec-building-image NixOS Manual: Building a NixOS (Live) ISO]. | |||
</div> | |||
[[Category:NixOS]] | [[Category:NixOS]] | ||
[[Category:Deployment]] | [[Category:Deployment]] | ||
[[Category:Cookbook]] | [[Category:Cookbook]] |
Latest revision as of 04:02, 9 August 2024
Мотивация
Создвние модифицированного образа NixOS из имеюшийся системы имеет множество преимуществ:
- Ensures authenticity.
- Нет необходимости в интернет доступе.
- В собстенный образ легко добавить пакеты и изменять конфигурацию.
Сборка
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 ];
}
Сборка образа с помощью:
nix-build '<nixpkgs/nixos>' -A config.system.build.isoImage -I nixos-config=iso.nix
В качестве альтернативы используйте Nix Flakes для создания установочного образа ISO, используя ветку nixos-24.05
в качестве источника nixpkgs:
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 ];
})
];
};
};
};
}
Следующие команды создадут ISO-образ:
# git init
# git add flake.nix
# nix build .#nixosConfigurations.exampleIso.config.system.build.isoImage
Готовый образ может быть найден а result
:
$ ls result/iso/
nixos-24.05.20240721.63d37cc-x86_64-linux.iso
Тестирование образа
Чтобы просмотреть содержимое образа ISO, выполните следующие действия:
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
Чтобы загрузить образ ISO в эмуляторе:
$ nix-shell -p qemu
$ qemu-system-x86_64 -enable-kvm -m 256 -cdrom result/iso/nixos-*.iso
SSH
В вашем iso.nix:
В вашем 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"
];
...
}
Статический IP-адрес
Статические IP-адреса можно задать в самом образе. Это может быть полезно при установке VPS.
Статический IP-адрес может бвть установлен в образе. Это может быть полехно для установки на VPS.
{
...
networking = {
usePredictableInterfaceNames = false;
interfaces.eth0.ip4 = [{
address = "64.137.201.46";
prefixLength = 24;
}];
defaultGateway = "64.137.201.1";
nameservers = [ "8.8.8.8" ];
};
...
}
Ускорение сборки
Процесс сборки может быть медленным из-за сжатия.
Процессс сборки медленный из-за сжатия.
Вот некоторые значения времени для nix-build
:
squashfsCompression | Время | Размер |
---|---|---|
lz4 |
100s | 59% |
gzip -Xcompression-level 1 |
105s | 52% |
gzip |
210s | 49% |
xz -Xdict-size 100% (По умолчанию) |
450s | 43% |
See also: mksquashfs benchmarks
Если вам не важен размер файла, вы можете использовать более быстрое сжатие, добавив этот параметр к вашему iso.nix
:
{
isoImage.squashfsCompression = "gzip -Xcompression-level 1";
}