Though, it's limited compared to flakes. I supposed that's better than nothing.
12 KiB
This is my NixOS config as a Nix flake.
I finally have some time trying to grok flakes and redo my NixOS config from scratch after leaving it for some time (because I have work and have to quickly set things up without me trying to debug how NixOS works). Here is the result.
Getting started
Caution
|
Despite being a NixOS system, it isn’t entirely reproducible to the point of installing this config will work out-of-the-box. It has some things needed in the first place to work like my external backup setup where it needs my SSH private keys to work in the first place. Nonetheless, the parts is it isn’t reproducible is only about 10% of this config. Everything else is fine and dandy. Oh right… Don’t expect everything is working in each commit but I’m doing my best to make them build successfully in each, yeah? |
Hey there, fellow traveler! You’ve fell into the rabbit hole we call Nix where it leads to other rabbit holes such as functional package management, reproducibility, declarative systems, and immutable operating systems.
This is one of the many tickets to that rabbit hole, allow me to be your guide in this mark:[painful] wonderful declarative journey. Hope to see you on the other side!
Installation
Since this uses Nix flakes, you should have Nix v2.4 and above installed.
If you’re going to install one of my NixOS configs, be sure to download the unstable versions from their release page. As an additional option, you can also use my personalized NixOS installers which is primarily intended for me configs.
This primarily uses Nix flakes so you can have a preview of what’s available in my config.
nix flake show github:foo-dogsquared/nixos-config
It should export my NixOS configurations of my different hosts (of only one so far excluding VMs and VPSs ;p) among other things.
To install it, run the nixos-install --flake github:foo-dogsquared/nixos-config#ni
.
(Please see the respective appropriate host README for more information.)
Tip
|
If you found some error regarding something in restricted mode, you can run the installation with --impure flag (i.e., nixos-install --impure --flake github:foo-dogsquared/nixos-config#ni ).
|
What’s in my flake?
You can see the full details with nix flake show
.
As a helpful summary, here’s what my flake should contain sorting from the most interesting and helpful outputs to the most boring and unnecessary.
-
packages
contains my custom packages. It supports the default list of systems as defined fromflake-utils
. -
devShells
from my custom environments. Similar tohomeManagerConfigurations
, you can easily use it outside of NixOS. -
homeManagerConfigurations
contains my various home-manager configurations from./users/home-manager/
. The neat thing about it is you can easily install it in a non-NixOS Linux distro. -
nixosConfigurations
which is where you can install my various NixOS configurations directly (e.g.,nixos-install --flake MY_FLAKE_URL#HOST
). This mainly uses the hosts configuration. -
homeManagerModules
are where my custom home-manager modules to be exported. [1] -
nixosModules
are composed from NixOS modules defined in./modules/nixos
. It can be used as additional modules for your own NixOS config in case you want to use mine for whatever reason. [2] -
templates
which contains my templates. Though, these are just templates mostly for my own purposes so it is not as useful as the other outputs. -
lib
is defined from my custom library. It’s another unnecessary export but it’s there.
The remote repo
For a complete overkill, we use a CI to further the configuration abomination. It uses GitHub workflows to enable things such as…
-
Automatically building my custom packages and sending them to my binary cache to easily distribute it for others.
-
Building my personalized NixOS installers and making a release out of it.
-
Testing the flake outputs (in progress lel).
Project structure
Last and foremost, we have the project directory — the environment you’ll be living in for the next year, tinkering your Nix configs. . It is required to be familiar with the workspace, after all. My configuration takes a lot of cues from devos (which is unfortunately is a lot to take if you’re just beginning to grok Nix as a whole).
My NixOS config should look like the following:
nixos-config
├── hosts/
├── lib/
├── modules/
├── pkgs/
├── secrets/
├── shells/
├── templates/
├── users/
├── default.nix
├── flake.lock
├── flake.nix
└── README.adoc
Most of the said folders are related to a flake output attribute, see What’s in my flake? for more details.
-
./hosts/
contain machine-specific configuration. This usually configures like the hardware setup, timezone, and users. Host configurations are also exported in the flakes inoutputs.nixosConfigurations
. -
./modules/
contain my custom modules including NixOS and home-manager modules. For more information, see the related documentation. -
./pkgs/
contains my custom packages. It is exported in the flakes atoutputs.packages
compiled through various systems. -
./secrets/
contains my secrets managed with agenix. [3] -
./shells/
contains my development shells for interacting with the usual type of projects. Setting this up can bring benefits outside of NixOS (unless you’re interacting with projects with any OpenGL-related stuff). [4] -
./templates/
contains my custom templates handy for quickly initializing for various types of projects. -
./users/
contains my home-manager configurations. It is exported in the flakes atoutputs.homeConfigurations
. For more information, see the related documentation.
TODO
In order of priority:
-
✓ Create custom modules.
-
✓ Create a themes system similar to this NixOS config.
-
✓ Create a good workflow for creating ISOs.
-
✓ Create development shells.
-
✓ Manage secrets with agenix.
-
❏ Create a good workflow for tests.
-
✓ Automate backups with NixOS config.
-
✓ Create custom packages and export it to flakes. (Maybe consider making it to upstream)
-
✓ Create cluser-wide configs.
-
✓ Create host-wide configs.
-
✓ Create user-specific configs with home-manager.
-
✓ Steal Get some ideas from this overengineered template.
-
✓ Make use of other established utilities such as digga, flake-utils-plus, and home-manager once I’m familiar to create my own Nix programs.
Out of scope:
-
Set most program configurations with Nix. This is especially applicable to programs I always use such as my text editor configs.
-
The reason: managing them can be chaotic when applied with Nix. The potential for it is pretty nice especially when seen with similar implementations such as Guix home environment. However, I don’t want to rebuild it every time I change it.
-
Plus, most of my applications are now installed using Flatpak anyways. It is a tad easier to manage configurations installed this way (e.g., just copy
~/.var
between your systems or make backups with it).
-
-
Migration of my dotfiles. I still use it on other non-NixOS systems.
-
To be a configuration framework. This is my personal configuration which means experimentation will always be here. Sudden changes can happen at any point.
Frequently asked questions (FAQ)
More like "Most anticipated questions (MAQ)" since almost no one asked me about this yet. :) However, it doesn’t roll off the tongue.
-
Hello! I’m new to Nix and NixOS, where should I start?
Oh no, you’ve seen the multiple configurations from other systems, didn’t you? I hope you’re ready for some time understanding because the learning curve is steeper than the Troll Wall. I’ve written a blog post regarding my experience with Nix with a bunch of links for getting started. Fortunately [5], it is mostly the same experience now that I’ve revisited it. (That said, Nix Pills is getting better!)
For a more practical start, I recommend to look into several configurations to see the general gist of configuration with Nix. Here’s a few I personally dug into:
-
Any requirements for this setup?
You only need Nix 2.4 installed with the experimental features for Nix command and flakes enabled (i.e.,
experimental-features = nix-command flakes
). -
Hey! I have an error something like
/nix/${HASH}-nmd/
from my installation. Why it doesn’t work?This error seems to be related to home-manager. See this issue for more details. Basically, you have to add
--impure
flag when runningnixos-install
. -
What is my experience on Nix flakes?
I LIKE IT! There are still some hiccups like the strict tie-in to Git which leads to strange experience like having to add untracked files just to be recognized. However, this feature is still in the works so no surprise there.
With that said, it is workable to be a daily part of the NixOS experience especially with the benefits of Nix flakes.
-
More user-friendly compared to Nix channels.
-
Just one reference file to know what is being exported from a project.
-
Unification with commonly-agreed schemas.
This feature somewhat helped me understand more about the Nix language, oddly. I guess those lightbulb moments can come from random places.
-
-
Is this based from devos?
Yes but I’ve created this from scratch. One of my goals when creating this config is to use as little dependency as much as possible and to understand more what’s going under the hood with Nix. At the time I’ve rewritten this configuration, I have little idea about Nix as a language and I find devos to be overwhelming so I doubled down to create from scratch.
However, I can say that my configuration is moving in a similar direction to devos (which is intended to be modified anyways) as I explore more of Nix. In fact, I’ve based much of my config from it and may even be ended up as one. It is nice that such a project exists serving as a reference for bigger configurations.
Inspirations
I stole got several parts of this configuration from the following projects:
-
devos, an overengineered configuration framework. I’m slowly grokking Nix and its ecosystem so I didn’t use this outright. Though, this is where my config is heading to be and instead slowly making parts of my config based from this template.
-
digga, an flake utility library for your overengineered config. I also stole parts of it for my custom library. I may have to use this at some point.
-
hlissner’s dotfiles, the original inspiration for this functional abomination of a configuration. Very nice.