2021-02-14 02:38:20 +00:00
|
|
|
# From NixOS
|
|
|
|
|
|
|
|
## Generate Configuration
|
2021-04-22 23:10:02 +00:00
|
|
|
Assuming you're happy with your existing partition layout, you can generate a
|
2021-02-14 02:38:20 +00:00
|
|
|
basic NixOS configuration for your system using:
|
|
|
|
```sh
|
2021-10-07 23:53:20 +00:00
|
|
|
bud up
|
2021-02-14 02:38:20 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
This will make a new file `hosts/up-$(hostname).nix`, which you can edit to
|
|
|
|
your liking.
|
|
|
|
|
2021-04-27 01:29:05 +00:00
|
|
|
You must then add a host to `nixos.hosts` in flake.nix:
|
|
|
|
```nix
|
|
|
|
{
|
|
|
|
nixos.hosts = {
|
|
|
|
modules = hosts/NixOS.nix;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2021-02-14 02:38:20 +00:00
|
|
|
Make sure your `i18n.defaultLocale` and `time.timeZone` are set properly for
|
2021-05-10 19:22:16 +00:00
|
|
|
your region. Keep in mind that `networking.hostName` will be automatically
|
2021-04-27 01:29:05 +00:00
|
|
|
set to the name of your host;
|
2021-02-14 02:38:20 +00:00
|
|
|
|
2021-04-19 02:26:27 +00:00
|
|
|
Now might be a good time to read the docs on [suites](../concepts/suites.md) and
|
|
|
|
[profiles](../concepts/profiles.md) and add or create any that you need.
|
2021-02-14 02:38:20 +00:00
|
|
|
|
|
|
|
> ##### _Note:_
|
|
|
|
> While the `up` sub-command is provided as a convenience to quickly set up and
|
|
|
|
> install a "fresh" NixOS system on current hardware, committing these files is
|
|
|
|
> discouraged.
|
|
|
|
>
|
|
|
|
> They are placed in the git staging area automatically because they would be
|
|
|
|
> invisible to the flake otherwise, but it is best to move what you need from
|
|
|
|
> them directly into a host module of your own making, and commit that instead.
|
|
|
|
# Installation
|
|
|
|
|
2021-04-22 23:10:02 +00:00
|
|
|
Once you're ready to deploy `hosts/my-host.nix`:
|
2021-02-14 02:38:20 +00:00
|
|
|
```sh
|
2021-10-07 23:53:20 +00:00
|
|
|
bud my-host switch
|
2021-02-14 02:38:20 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
This calls `nixos-rebuild` with sudo to build and install your configuration.
|
|
|
|
|
|
|
|
> ##### _Notes:_
|
|
|
|
> - Instead of `switch`, you can pass `build`, `test`, `boot`, etc just as with
|
|
|
|
> `nixos-rebuild`.
|
|
|
|
>
|
|
|
|
> - It is convenient to have the template living at `/etc/nixos` so you can
|
|
|
|
> simply `sudo nixos-rebuild switch` from anywhere on the system, but it is
|
|
|
|
> not required.
|
|
|
|
|