this post was submitted on 12 Nov 2023
84 points (96.7% liked)

Linux

48340 readers
460 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
 

So I've recently taken an interest in these three distros:

All of these offer something very interesting:
Access to (basically) all Linux-capable software, no matter from what repo.

Both NixOS and blendOS are based on config files, from which your system is basically derived from, and Vanilla OS uses a package manager apx to install from any given repo, regardless of distribution.

While I've looked into Fedora Silverblue, that distro is limited to only install Flatpaks (edit: no, not really), which is fine for "apps", but seems to be more of a problem with managing system- and CLI tools.

I haven't distro hopped yet, as I'm still on Manjaro GNOME on my devices.


What are your thoughts on the three distros mentioned above?
Which ones are the most interesting, and for what reasons?

Personally, I'm mostly interested in NixOS & blendOS, as I believe they may have more advantages compared to Arch;

What do you think?

you are viewing a single comment's thread
view the rest of the comments
[–] 2xsaiko@discuss.tchncs.de 1 points 1 year ago

There's two different ways of identifying a nix package: its attribute path in the package set, and the name it self-identifies as. Here's an example where those differ, firefox-esr. Its attribute path is firefox-esr while the package name it reports is firefox.

It's very fast to find a package by its attribute path since that's essentially one or more map lookups. In contrary, the package name isn't unique (for example, firefox and firefox-esr both have a package name of "firefox" because they are built from the same package file just with different sources) and also doesn't have an index, so to find a package with a matching name you have to search through the entire package set and evaluate every package to get its name and check if it matches.

nix-env -i searches packages by their package name, which as a consequence makes it slow and also unreliable since you might not get the package you were looking for, but instead another with the same name. nix-env -iA somewhat fixes this by installing packages by their attribute path, but even if you use that you get the same issues with nix-env --upgrade since that always searches for packages to update by the installed packages' names (it might even replace one package with a completely unrelated one which coincidentally has the same name!).

The new nix profile however stores the attribute paths a package was installed from so doesn't have any of these problems.