Disko: Difference between revisions

From NixOS Wiki
imported>B-
Add Disko documentation index towards the top of the page
update disko config to one from this decade
Line 8: Line 8:


{{file|disko-config.nix|nix|<nowiki>
{{file|disko-config.nix|nix|<nowiki>
{ disks ? [ "/dev/vda" ], ... }: {
{
   disko.devices = {
   disko.devices = {
     disk = {
     disk = {
       vdb = {
       main = {
         device = builtins.elemAt disks 0;
         device = "/dev/vda";
         type = "disk";
         type = "disk";
         content = {
         content = {
           type = "table";
           type = "gpt";
          format = "gpt";
           partitions = {
           partitions = [
             ESP = {
             {
               end = "500M";
               name = "ESP";
               type = "EF00";
              start = "1MiB";
               end = "500MiB";
              bootable = true;
               content = {
               content = {
                 type = "filesystem";
                 type = "filesystem";
Line 28: Line 25:
                 mountpoint = "/boot";
                 mountpoint = "/boot";
               };
               };
             }
             };
             {
             root = {
               name = "root";
               name = "root";
              start = "500MiB";
               end = "-0";
               end = "100%";
              part-type = "primary";
               content = {
               content = {
                 type = "filesystem";
                 type = "filesystem";
Line 39: Line 34:
                 mountpoint = "/";
                 mountpoint = "/";
               };
               };
             }
             };
           ];
           };
         };
         };
       };
       };
Line 53: Line 48:


<syntaxhighlight lang="console">
<syntaxhighlight lang="console">
# sudo nix run github:nix-community/disko -- --mode zap_create_mount ./disko-config.nix
# sudo nix run github:nix-community/disko -- --mode disko ./disko-config.nix
</syntaxhighlight>
</syntaxhighlight>


Alternativley use a disk layout configuration of a [https://github.com/Lassulus/flakes-testing remote repository] containing a <code>flake.nix</code> file as an entry point. The <code>--arg</code> parameter specifies the target disk <code>/dev/sda</code>.
Alternativley use a disk layout configuration of a [https://github.com/Lassulus/flakes-testing remote repository] containing a <code>flake.nix</code> file as an entry point.


<syntaxhighlight lang="console">
<syntaxhighlight lang="console">
# sudo nix run github:nix-community/disko -- --mode zap_create_mount --flake github:Lassulus/flakes-testing#fnord --arg disks '[ "/dev/sda" ]'
# sudo nix run github:nix-community/disko -- --mode disko --flake github:Lassulus/flakes-testing#fnord
</syntaxhighlight>
</syntaxhighlight>


Line 97: Line 92:
         ./disko-config.nix
         ./disko-config.nix
         {
         {
           _module.args.disks = [ "/dev/vda" ];
           disko.devices.main.device = nixpkgs.lib.mkForce "/dev/vda";
         }
         }
         ./configuration.nix
         ./configuration.nix

Revision as of 19:14, 19 July 2024

Disko is a utility and NixOS module for declarative disk partitioning.

Disko Documentation Index

Usage

The following example creates a new GPT partition table for the disk /dev/vda including two partitions for EFI boot and a bcachefs root filesystem.

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 = "/";
              };
            };
          };
        };
      };
    };
  };
}

The following command will apply the disk layout specified in the configuration and mount them afterwards. Warning: This will erase all data on the disk.

Warning: The disko commands will erase all existing data on your disk and repartition it according to the given configuration.
# 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 disko --flake github:Lassulus/flakes-testing#fnord

The commands above requires Flake features available on your system.

To verify both partitions got mounted correctly, run

# mount | grep /mnt

Configuration

In case the NixOS base system was installed on a partition layout bootstrapped with Disko, the disk config itself can be integrated into the system. First copy the file, for example disko-config.nix into your system configuration directory

# cp disko-config.nix /etc/nixos/

Add the Disko module on a flake-enabled system. Insert the required input and reference it and your disko-config.nix in the modules section. For alternative installation methods consult the Disko quickstart guide.

/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
      ];
    };
  };
}

Ensure that there are no automatically generated entries of fileSystems options in /etc/nixos/hardware-configuration.nix. Disko will automatically generate them for you. Rebuild your system to apply the Disko configuration.