12
Getting started with NixOS - looking for tutorials
(discuss.tchncs.de)
NixOS is a Linux distribution built on top of the Nix package manager. Its declarative configuration allows reliable system upgrades via several official channels of stability and size.
This community discusses NixOS, Nix, and everything related.
Currently I am playing around in a virtual machine to get to know NixOS and find out what I can do with it.
I'd like to set up a usable everyday desktop configuration with "everything".
This includes typical desktop applications like Firefox, Thunderbird, LibreOffice ... development tools like Git, PyCharm, VS Code, ... all those little things I need to work productively like Nextcloud desktop client, KeePassXC, Zim and many more.
And I'd like to have zsh as my default shell with my own custom theme and some dotfiles for different applications that currently reside in a git repo that I clone to every machine I use.
I know this is a lot and I don't expect to get this all up and running in an afternoon.
It's just that I find it very hard to find the next bit of information I need. For example I found snippets to put into my
configuration.nix
long before I found out where to find this file (/etc/nixos/configuration.nix
).From the answers so far I gather that there really is no (official or unofficial) documentation to tell NixOs newbies how to start, so everyone just makes do with the things they find.
So I think I'll just fight my way through this jungle, too ;-)
The price that's waiting at the other and seems to be totally worth it!
If anyone has valuable tips or links to help me achieve something from the things I listed, those would be very much appreciated! :-)
Yea it's definitely a jungle haha, it also seems they're changing things up a bit with where the most recent docs might be hosted
https://search.nixos.org/
so, if you searched for vscode in that link, then click the "NixOS Configuration" button, you can see
or if you're using the
with
convention to factor out the pkgs object/contextual keyword(not sure if that's the right name)for zsh, just having this in your configuration.nix should work https://nixos.wiki/wiki/Command_Shell
Again, these values should be inserted after the function definition of your configuration.nix
for example.
Something I've noticed from developing on nix, When the headaches of nix appear, the solution might be harder, but I usually end up with a better solution than what I was going for before. Some examples:
My resume is compiled in Latex. I tried the pdflatex package in nix but it gave rendering issues. Then the nix community recommended tectonic and i'm getting better compilation times, logging, clean up...
PIP is a garbage package manager, and it's garbageness sometimes makes native python development a headache in nixos. However, using poetry2nix, not only could I define development environments, it was also ready for packaging on PIP
Sometimes you might want to separate some parts of your configuration away from your global system config at /etc/nixos/configuration.nix. That's nix-shell, nix-develop, nix-build, and flakes are for. I'm not a pro at flakes yet, but I think I got the gist, here's an example of when I wish I could have used a flake:
I use discord but discord itself is garbage. Vesktop is a better 3rd party client for discord. Unfortunately, I had to remove it from my configuration.nix the last few weeks because one of its dependencies wasn't packaged right, causing my entire system to not build. If I had used a flake, I could have isolated that dependency from the rest of my build, while still tracking its integration with my system. I believe this could have allowed me to update the rest of my system, while still defining the errenous app as part of my system. Flakes are supposed to be more reproducible as well, since they require sha256 git commits, whereas other package managers only ask for a subjective version number
There's a lot to learn with nix but even if I don't stick with it long term I feel like It's making me a smarter software engineer since a declarative/functional paradigm tends to match the natural language more. It also is the most restrictive design paradigm, which means it's brief but so simple it can be hard to understand as a consequence. Since it's so restrictive, it's also a subset of all other paradigms. You declare what you want, ideally, you don't have to set anything up. I never had an easier time getting cuda drivers for ML Training setup than on NixOS because of this
Something I enjoyed doing, was setting up my user profile to let me ssh in only with whitelisted ssh keys, as well as setting up a systemd script to handle some start up routines on my OS. I think that can be a gentle introduction to how you can configure other parts of your operating system. I'm going to try and set up a CI/CD/CT pipeline with it next I believe
Edit: The next thing I need to do as well, is consolidate my user configs with the home manager functionality. I use a KVantum Theme engine on top of plasma, and while those apps are installed in my system, the configuration of which theme to automatically load should be integrated with the text config aspects of nixos. Currently, I "Imperatively" configured those by "Opening the app and clicking", which will get erased/not be reproducible if I ever rebuild my nixos on a new computer
Another funny thing with functional programming... sometimes the fix is as simple as
Even though I had pipewire enabled as a service and everything, that one line needed to be there haha
I have to do this weekly with my bleeding edge Hyprland setup.
I've been using nvfetcher to feed my nightlies addiction for software that doesn't have a flake.
Only major hiccup I had was pulling a few packages from nixpkgs master due to a bug that got introduced in unstable for electron apps before it hit cachix. Wasn't expecting it to take a day to compile everything that depended on it.
10/10 would highly recommend flakes.