os/doc/concepts/hosts.md

62 lines
2 KiB
Markdown
Raw Normal View History

2021-02-14 02:38:20 +00:00
# Hosts
Nix flakes contain an output called `nixosConfigurations` declaring an
attribute set of valid NixOS systems. To simplify the management and creation
of these hosts, devos automatically imports every _.nix_ file inside this
directory to the mentioned attribute set, applying the projects defaults to
each. The only hard requirement is that the file contain a valid NixOS module.
2021-02-14 02:38:20 +00:00
As an example, a file `hosts/system.nix` will be available via the flake
output `nixosConfigurations.system`. You can have as many hosts as you want
and all of them will be automatically imported based on their name.
2021-02-14 02:38:20 +00:00
For each host, the configuration automatically sets the `networking.hostName`
attribute to the name of the file minus the _.nix_ extension. This is for
convenience, since `nixos-rebuild` automatically searches for a configuration
matching the current systems hostname if one is not specified explicitly.
You can set channels, systems, and add extra modules to each host by editing the
`nixos.hosts` argument in flake.nix. This is the perfect place to import
host specific modules from external sources, such as the
[nixos-hardware][nixos-hardware] repository.
2021-02-14 02:38:20 +00:00
It is recommended that the host modules only contain configuration information
specific to a particular piece of hardware. Anything reusable across machines
2021-04-19 02:26:27 +00:00
is best saved for [profile modules](./profiles.md).
2021-02-14 02:38:20 +00:00
2021-04-19 02:26:27 +00:00
This is a good place to import sets of profiles, called [suites](./suites.md),
2021-02-14 02:38:20 +00:00
that you intend to use on your machine.
2021-02-14 02:38:20 +00:00
## Example
flake.nix:
```nix
{
nixos = {
imports = [ (devos.lib.importHosts ./hosts) ];
hosts = {
librem = {
channelName = "latest";
modules = [ nixos-hardware.nixosModules.purism-librem-13v3 ];
};
};
};
}
```
2021-02-15 00:41:15 +00:00
hosts/librem.nix:
2021-02-14 02:38:20 +00:00
```nix
{ suites, ... }:
2021-02-14 02:38:20 +00:00
{
imports = suites.laptop;
2021-02-14 02:38:20 +00:00
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
fileSystems."/" = { device = "/dev/disk/by-label/nixos"; };
}
```
[nixos-hardware]: https://github.com/NixOS/nixos-hardware