82
NixOS musings (programming.dev)
submitted 1 year ago by Noodlez@programming.dev to c/linux@lemmy.ml

Hi all,

I've been using NixOS for a while now (About a month now) and I've been loving it, but I've had some thoughts lately.

I understand that Nix(OS)'s claim to fame is the fact that packages are reproducible. All dependencies are versioned and all packages are rollback-able (although not sandboxed). With proper maintenance (nix-collect-garbage mostly), the problem with space is mostly mitigated.

But what if a package's dependencies are out of date? These just stay out of date with their possible security problems as well. Not just that but it's (nearly) impossible to actually do your own manual imperative editing of packages to solve a quick problem since everything is declarative.

Not just this, but Nix uses mostly its own configuration methodology, so isn't this a maintenance nightmare as config files change and options are added/removed? Home manager is a prime example of this potential problem.

Plus more technologies being introduced on top of it to solve problems that seem already solved? (Flakes mostly come to mind).

I have come to the realiziation that, unlike a traditional distro like Arch/Alpine which I used previously, if maintenance dies I cannot feasibly maintain it myself, since it's mostly "magic". The upkeep of all the configurations plus all the dependency packages, and making sure each package compiles and matches the build configuration is a nightmare. I can barely do it with my own personal projects.

Anyways that's kinda it just expressing thoughts about it. I do love Nix(OS) and plan to continue using it. It's amazing, and its capabilities are matched by few to none, and from a user perspective it is an extremely seamless and simple OS. It's mostly from a maintainer perspective that I had.

you are viewing a single comment's thread
view the rest of the comments
[-] snek_boi@lemmy.ml 18 points 1 year ago

The out of date problem you mention is something Nix contemplates. As of a couple hours ago, if you try to install Etcher (Balena Etcher, that is), you will get a message saying there's an out of date dependency: Electron.

You can still try to install End of Life packages, but you have to type an instruction the 'compiler' tells you to type out. In other words, you have to be deliberate about installing out of date dependencies.

The other problem I understood it as "if I declaratively do this and then imperatively do that, how do I keep track of it all?". If that is indeed what you're asking, you're right. That's a problem. That's why I try to keep everything in the config.

I've been using Nix now for a couple of months and the configuration file has been a great friend. Sometimes I don't know how to configure something and I get lost and worried, but the community has helped me to fix my problems- .

[-] Noodlez@programming.dev 1 points 1 year ago

I guess I could've worded this better but my second problem was: I would like to do everything declaratively. What do I do when a package doesn't have its own declarative configuration options? Before it was simple because it was imperative, so I could just change the config file, but not so much in NixOS.

[-] priapus@sh.itjust.works 2 points 1 year ago

Having a config file means a package can be done declaratively. You can just use a nix option to create the config file.

[-] Noodlez@programming.dev 1 points 1 year ago

I didn't know this before, but a lot of comments said the same! I think I'll start doing this.

load more comments (5 replies)
load more comments (5 replies)
this post was submitted on 12 Jul 2023
82 points (97.7% liked)

Linux

48199 readers
1905 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS