Hacker News new | past | comments | ask | show | jobs | submit login

Isn't NixOS immutable? If so, surprised it wasn't mentioned.



I certainly consider it to be immutable.

But NixOS is immutable in a very different way to all the mention distos, which are focused on containers, isolation, and layers; Maybe the author doesn't consider it to be in the same category?

Personally, I've decided that NixOS is not for me. The concept is great, but the actual experience seems to be held back by Nix (the language and the tool) being hard to understand and debug.


Have you ever used the nix repl? I find between that and having the failing build keep its working directory around for inspection, it's always easy to debug thing. I guess the third tool is overlaying the equivalent of debugging into derivations but that's rare.


I did.

The problem with nix repl, is that it only seems to help if you already understand both nix and how the derivations are actually implemented in nix. It's pretty useless as a learning tool.


I don't think that's true. Because the main way I learned those things was poking in the repl. Hitting tab and stuff. And reloading changes to files or overlays and debugging what happened by inspecting things.

It's the same as learning Haskell. Outside of syntax and some basics, you don't need to have deep knowledge to use ghci. And Nix and Haskell are both just substitution-based evaluation (lambda calculus) which imo is 80% of understanding them.


I really don't know how much of the problem is me.

For some reason, I have a really hard time groking Haskell, and Nix seems to fit in the same boat. I don't know why.

It's not the functional programming. I love doing functional style programming in Rust, Python and recent versions of c++. And I didn't have any problem with Prolog and Lisp for those few university courses. I have a suspicion that my brain just finds the concept of lazy evaluation by default to be deeply offensive.

What I do know is that personally: I could never grasp Nix; The repl didn't help; The repl was the extent of the debug tooling; I never found good documentation to help me learn; and I was getting anxious at the thought of doing anything on that server.


I think openSuse also calls their rpm+btrfs snapshots solution immutable, but afaik it doesn't use containers.


Tried Guix?


I think technically NixOS is considered an atomic distro rather than immutable. You could mount the store rw and modify it, though you really shouldn't except in extreme cases.


Same for fedora CoreOS. RPM-ostree is just a bunch of symlinks and hard links just like NixOS is if I recall correctly. Or at least it used to be.


Not by default - some things like /etc/machine-id or SSH keys are not a part of your configuration and they're just generated in place and kept untouched. Plus you (or your software) can litter arbitrary files and they'll stay. And of course $HOME is a mess.

But with impermanence it can be effectively immutable.


Nor they have mentioned Puppy Linux.

It uses SquashFS images and layer them on each other. You can choose to save your modifications in a new image, or discard them. E.g. you can run a Puppy Linux from a CD-R (one time writeable), by appending all your changes.

I think that's a great model to be immutable, but AFAIK Puppy Linux doesn't have the convenient tools to manage these snapshots, switch between them, roll back and such, and they don't seem to go in that direction. (I used Puppy Linux as my default system for a while, but I lost touch with them and I don't know how are they doing now.)


It gets super immutable when the impermanence modules are used.




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: