Disko/ru: Difference between revisions
Created page with "Добавьте модуль Disko в систему с поддержкой Flake. Вставьте нужный входной файл и ссылайтесь на него и на ваш файл <code>disko-config.nix</code> в разделе Модулей." Tags: Mobile edit Mobile web edit |
No edit summary |
||
Line 153: | Line 153: | ||
</nowiki>}} | </nowiki>}} | ||
Убедитесь, что в файле /etc/nixos/hardware-configuration.nix нет автоматически генерируемых записей опций <code>fileSystems</code> в <code>/etc/nixos/hardware-configuration.nix</code>. Disko автоматически сгенерирует их за вас. Пересоберите систему, чтобы применить конфигурацию Disko. | Убедитесь, что в файле /etc/nixos/hardware-configuration.nix нет автоматически генерируемых записей опций <code>fileSystems</code> в <code>/etc/nixos/hardware-configuration.nix</code>. | ||
Disko автоматически сгенерирует их за вас. Пересоберите систему, чтобы применить конфигурацию Disko. | |||
[[Category:Filesystem{{#translation:}}]] | [[Category:Filesystem{{#translation:}}]] |
Revision as of 14:17, 20 July 2024
Disko is a utility and NixOS module for declarative disk partitioning.
Использование
Следующий пример создаёт новую таблицу разделов GPT для диска /dev/vda
включая два раздела для EFI boot и корневой раздел файловой системы bcachefs.
disko-config.nix
{ disks ? [ "/dev/vda" ], ... }: {
disko.devices = {
disk = {
vdb = {
device = builtins.elemAt disks 0;
type = "disk";
content = {
type = "table";
format = "gpt";
partitions = [
{
name = "ESP";
start = "1MiB";
end = "500MiB";
bootable = true;
content = {
type = "filesystem";
format = "vfat";
mountpoint = "/boot";
};
}
{
name = "root";
start = "500MiB";
end = "100%";
part-type = "primary";
content = {
type = "filesystem";
format = "bcachefs";
mountpoint = "/";
};
}
];
};
};
};
};
}
disko-config.nix
{
disko.devices = {
disk = {
main = {
device = "/dev/vda";
type = "disk";
content = {
type = "gpt";
partitions = {
ESP = {
end = "500M";
type = "EF00";
content = {
type = "filesystem";
format = "vfat";
mountpoint = "/boot";
};
};
root = {
name = "root";
end = "-0";
content = {
type = "filesystem";
format = "bcachefs";
mountpoint = "/";
};
};
};
};
};
};
};
}
Следующая команда применит расположение дисков, указанное в конфигурации, и смонтирует их после этого. Внимание: При этом все данные на диске будут удалены.
# sudo nix run github:nix-community/disko -- --mode disko ./disko-config.nix
Alternativley use a disk layout configuration of a remote repository containing a flake.nix
file as an entry point.
# sudo nix run github:nix-community/disko -- --mode zap_create_mount ./disko-config.nix
Приведенные выше команды требуют наличия в вашей системе функций Flake.
Чтобы убедиться, что оба раздела смонтированы правильно, выполните команду
# mount | grep /mnt
Настройка
Если базовая система NixOS была установлена на макет раздела, развёртываемого с помощью Disko, сам конфиг диска может быть интегрирован в систему. Сначала скопируйте файл, например disko-config.nix
, в каталог конфигурации системы
# cp disko-config.nix /etc/nixos/
Добавьте модуль Disko в систему с поддержкой Flake. Вставьте нужный входной файл и ссылайтесь на него и на ваш файл disko-config.nix
в разделе Модулей.
/etc/nixos/flake.nix
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05";
disko.url = "github:nix-community/disko";
disko.inputs.nixpkgs.follows = "nixpkgs";
};
outputs = {self, nixpkgs, disko, ...}@inputs: {
nixosConfigurations.mysystem = inputs.nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
specialArgs.inputs = inputs;
modules = [
disko.nixosModules.disko
./disko-config.nix
{
disko.devices.main.device = nixpkgs.lib.mkForce "/dev/vda";
}
./configuration.nix
];
};
};
}
Убедитесь, что в файле /etc/nixos/hardware-configuration.nix нет автоматически генерируемых записей опций fileSystems
в /etc/nixos/hardware-configuration.nix
.
Disko автоматически сгенерирует их за вас. Пересоберите систему, чтобы применить конфигурацию Disko.