Creating a NixOS live CD/ru: Difference between revisions

From NixOS Wiki
Unabomberlive (talk | contribs)
Created page with "==See also== * [https://nixos.org/manual/nixos/stable/index.html#sec-building-image NixOS Manual: Сборка Live-образа NixOS]."
Unabomberlive (talk | contribs)
Replaced content with "== Мотивация =="
 
(20 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<span id="Motivation"></span>
== Мотивация ==
== Мотивация ==
Создание модифицированного NixOS LiveCD из существующей рабочей установки NixOS имеет ряд преимуществ:
 
* Обеспечение подлинности.
Создвние модифицированного образа 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 ==
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>
<div lang="en" dir="ltr" class="mw-content-ltr">
 
Alternatively, use Nix [[Flakes]] to generate a ISO installation image, using the <code>nixos-24.05</code> branch as nixpkgs source:
В качестве альтернативы используйте Nix [[Flakes]] для создания установочного образа ISO, используя ветку <code>nixos-24.05</code> в качестве источника nixpkgs:
</div>
 
{{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>
<div lang="en" dir="ltr" class="mw-content-ltr">
 
The resulting image can be found in <code>result</code>:
Готовый образ может быть найден а <code>result</code>:
</div>
 
<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, выполните следующие действия:
<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 68: 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 86: 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 103: 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 120: 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 125: Line 166:


Если вам не важен размер файла, вы можете использовать более быстрое сжатие, добавив этот параметр к вашему <code>iso.nix</code>:
Если вам не важен размер файла, вы можете использовать более быстрое сжатие, добавив этот параметр к вашему <code>iso.nix</code>:
<syntaxhighlight lang="nix">
<syntaxhighlight lang="nix">
{
{
Line 130: Line 172:
}
}
</syntaxhighlight>
</syntaxhighlight>
==See also==
 
<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%

Если вам не важен размер файла, вы можете использовать более быстрое сжатие, добавив этот параметр к вашему iso.nix:

{
  isoImage.squashfsCompression = "gzip -Xcompression-level 1";
}

См. Также