this post was submitted on 03 Jul 2025
179 points (96.4% liked)

Linux

58053 readers
115 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 6 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] traches@sh.itjust.works 40 points 2 months ago (7 children)

I like the idea of nixos, but I feel like it makes a bunch of daily sacrifices in order to optimize a task I do once every few years? I hardly ever get a new computer, but I install/uninstall/update/tweak packages on my system all the time. With a dotfile manager and snapshots, I get most of the benefit without any of the drawbacks.

[–] Phoenix3875@lemmy.world 14 points 2 months ago (1 children)

For DevOps, it provides consistency for every CI run and production deployment, especially when a whole system needs to be shipped.

[–] OhVenus_Baby@lemmy.ml 3 points 2 months ago (1 children)

I'm always on the go, swapping PCs, travelling for medical reasons. Buy, sell, trade hardware. Nix allows me to boot into my system as if I never left with a simple hardware config update script. Rock solid consistency.

[–] Ephera@lemmy.ml 8 points 2 months ago (1 children)

I feel like setting up a new machine is just the easiest to explain.

Personally, I find dotfiles messy, as you often just want to change one or two settings, but you always carry along the whole file with all kinds of irrelevant other settings. This also makes it impractical to diff two versions of those dotfiles, especially when programs write semi-permanent settings into there.

I guess, your mileage will vary depending on what programs or desktop environment you use.
For example, I love KDE, but they really don't do a good job keeping the config files clean. Nix Plasma-Manager generally fixes that, and for example allows defining the contents of the panel in a readable form.

[–] OhVenus_Baby@lemmy.ml -3 points 2 months ago (2 children)

I think you over complicating your view here. I daily nix. Your not carrying a bunch if dot files. You have one. A single nix. Config. That's it. It's not big, long, messy, what so ever. I have mine commented by section from boot order to auto updates and backups. Your talking about 150 lines of extremely short and almost self explanatory code. I came from mint having never used nix. I figured it out doing a custom luks install and the whole custom build from scratch in no time.

Your diff issue is overblown. The edits you make are small and you cannot get lost in multiple configs unless your doing entire system writes which you would never do. I use a dead light weight diff GUI or terminal. This has to be one if the cleanest, maintenance free distros I have ever used.

It doesn't seem you have truly driven Nix with this take. No program writes directly to your config, even if there was say your temp scenario you reboot and temps would wipe away like you never did them unless you rebuild nix config. Most of your concerns would fall away once you really drove nix to see how it functions.

[–] Edie@lemmy.ml 7 points 2 months ago

Ephera isn't talking about nix when they say dot files.

[–] Ephera@lemmy.ml 4 points 2 months ago (1 children)

Yeah, you understood my comment entirely the wrong way around. When I say "dotfiles", I mean the non-Nix way of managing application configurations. Nix Home-Manager happens to write to these dotfiles, but that means I don't have to deal with the dotfiles myself.

[–] dinckelman@lemmy.world 8 points 2 months ago

This is a good example of what people consistently overlook/misunderstand, when it comes to Nix.

Obviously you can remount a /home, or just pull the dotfiles from a personal repo, but the strength of Nix is also in that I can re-create my entire config exactly how it is defined. If i were to setup a machine completely from scratch, with a mature enough config, it will get me from 0 to my exact desktop completely unattended.

But there are also many more advantages to it, at least in my eyes. Let's take trying/tweaking new packages as an example. Yesterday I pulled an old repo for an Outer Wilds mod. The thing needs a dev environment, and a mod manager for the actual game. A nix shell got me both, I finished my work, and when I exit out of fish, both are gone, just as I wanted them to be.

Another good example would be partial os updates. I've used Arch for almost 9 years before switching to Nix, and pretty much a top3 Arch rule is not doing partial updates, or partial rollbacks. In case of a breakage, I would have to manually redownload an older version of a tarball, pacman -U the package, and then hope i'm not cooked. In the case of gcc incompatibilities, it can quickly become a massive pain in the ass. My nix flake would never experience this problem, because I already have two different scenarios available - either i build based on an older lockfile from my git repo, or I create an overlay for a specific input I need, so that it still pulls what it needs, and doesn't interfere with the rest of my system

[–] Flipper@feddit.org 7 points 2 months ago (1 children)

It also is an option to ensure everyone has the same dev environment.

[–] atzanteol@sh.itjust.works 11 points 2 months ago (1 children)
[–] Mihies@programming.dev 3 points 2 months ago (2 children)

The docker is not bare metal though.

[–] atzanteol@sh.itjust.works 4 points 2 months ago

sigh, yes it is.

[–] utopiah@lemmy.ml 4 points 2 months ago (2 children)

Does it matter if the overhead is practically irrelevant?

[–] trevor@lemmy.blahaj.zone 9 points 2 months ago (2 children)

The biggest downside to containers vs. Nix for me is that Nix can produce binaries for Linux and macOS, whereas docker only helps with Linux unless you can perform literal magic to cross-compile your project on Linux for macOS.

Containers also don't give you reproducible environments, and Nix does.

That said, Nix documentation is ass, so I usually end up going with containers because they require far less suffering to get working because writing a containerfile is much easier than guessing how to hobble together a Nix flake with a mostly undocumented language.

[–] atzanteol@sh.itjust.works 2 points 2 months ago (1 children)

Containers also don't give you reproducible environments, and Nix does.

Of course it does. 🙄

[–] trevor@lemmy.blahaj.zone 2 points 2 months ago (1 children)

Care to elaborate? Containers give you repeatable environments, which are not the same thing as reproducible environments.

[–] atzanteol@sh.itjust.works 0 points 2 months ago* (last edited 2 months ago) (1 children)
docker build . -t docker.company.com/build-env:1.0 && docker push docker.company.com/build-env:1.0

But for like 99% of development teams "repeatable" is Good Enough(tm).

[–] trevor@lemmy.blahaj.zone 4 points 2 months ago* (last edited 2 months ago) (2 children)

So, containers do not get you reproducibility.

For dev environments, repeatable is okay. If you want actually reproducible binaries that you can ship, Nix is better fit for that purpose.

[–] gedhrel@lemmy.world 1 points 2 months ago (1 children)

I'm not quite sure why you fetishise a bit-for-bit over semantic equivalence. Doesn't it turn "it works on my machine" into "it works on my machine as long as it has this sha: ... "?

[–] trevor@lemmy.blahaj.zone 1 points 2 months ago

I'm not quite sure why you think pointing out someone's confidently incorrect claim that containers do give you reproducible environments means that I fetishsize anything?

But if you genuinely want to know why reproducibility is valuable, take a look at https://reproducible-builds.org/.

I was quite happy to see that Debian and Arch have both made great strides into making tooling that enables reproducible packages in recent times. It's probable that, because of efforts like this, creating reproducible builds will become easier/possible on most Linux environments, including traditional container workflows.

For now though, Nix Flakes are much better at enabling reproducible builds of your software than traditional containers, if you can suffer through Nix not being documented very well. This article covers some more details on different build systems and compares them with Nix Flakes if you want more concrete examples.

FWIW, I think that containers are awesome, and using them for dev environments and CI tooling solves a lot of very real problems ("it works on my machine", cheap and easy cross-compilation for Linux systems, basic sandboxing, etc.) for people. I use containers for a lot of those reasons. But if I need to make something reproducible, there are better tools for the job.

[–] atzanteol@sh.itjust.works -3 points 2 months ago (1 children)

So, containers do not get you reproducibility.

You absolutely do. If you build a container and publish it you will pull down that exact thing every time. How is that not "reproducibility"?

You no what though? Scratch that - who gives a fuck? Bit-for-bit reproducibility takes far more effort than it's worth anyway. Even NixOS isn't completely reproducible. It's a false goal.

For dev environments, repeatable is okay.

It's well more than good enough you mean.

If you want actually reproducible binaries that you can ship, Nix is better fit for that purpose.

Nobody really needs that.

[–] utopiah@lemmy.ml 2 points 2 months ago (1 children)

Feels very arbitrary. Why would I care about say MacOS versus FreeBSD or say NeXTSTEP (just to be provocative)?

Anyway I'm being pulled away from the actual argument, the "bare metal" argument is about performances, isn't it?

[–] iopq@lemmy.world 2 points 2 months ago* (last edited 2 months ago) (1 children)

Yes, the systems people actually use vs every system that exists. Very arbitrary

[–] utopiah@lemmy.ml 1 points 2 months ago

What I mean is that MacOS is proprietary and runs on specific hardware, it's by design not meant to be interoperable so it's not "just" popularity.

[–] Mihies@programming.dev 1 points 2 months ago (1 children)

It could if there are issues accessing hardware directly. Overhead is, as you said, not that important.

[–] utopiah@lemmy.ml 1 points 2 months ago

Isn't it what passthrough is for?

[–] OhVenus_Baby@lemmy.ml 5 points 2 months ago

I've used nixos exclusively lately. It's been awesome. No system scatter, clutter. It'd immutable. There's very slight driver hassle (you don't have GUI for drivers so a simple terminal command fetches everything you need.) in cinnamon. I came from mint. I have all basic commands in executable files on desktop for ease of hassle. It's not about rebuilding the system. Its about being hands off. Next to zero maintenance because not much in your system gets altered. I went for a full custom install from terminal. The only thing I personally miss being GUI is a firewall like UFW or GUFW.

Overall its more rock solid and workable than likely every distro I have ever tried. The feature set is nice, easy rollbacks, fucking cake backups. All you have to know is your entire system lives on one small editable file called nix. Configuration. Keep it in a micro SD or USB or any backup and it's as if you never left. Any changes you want you simply tweak in the config then reboot. If it breaks then select your previous gen number on boot and your exactly where you was before.

I diff my edits and keep copies, run auto backups, and more. It's so hands off that I haven't found a better replacement yet. My single biggest concern is long-term viability in the project.

[–] feddup@feddit.uk 5 points 2 months ago (1 children)

Loved nixOS but couldn't install PIA VPN gui and disliked the workarounds. Also doing .net dev was more awkward than I liked so went back to Arch and wrote some scripts to install all the packages I want instead. Love the idea of nixOS though.

[–] iopq@lemmy.world 1 points 2 months ago (1 children)

Package your own if you need it

[–] feddup@feddit.uk 4 points 2 months ago

I have no idea how and given there's been a lot of people asking the same thing I don't think it's as trivial as packaging some binaries.

[–] iopq@lemmy.world 4 points 2 months ago (1 children)

You only have one machine? I benefit from sharing configs between the laptop and the desktop. They are not the same, but I can easily copy paste a complex service I defined in my desktop to do the same thing on my laptop

[–] traches@sh.itjust.works 2 points 2 months ago (1 children)

I have a desktop, laptop, and a few VMs and servery things. Dotfile manager (yadm, which is a git wrapper) to sync personal settings, everything else I just do manually. The system-level configs are either different enough that standardizing them isn’t very helpful, or no more complicated than installing packages and activating services.

[–] iopq@lemmy.world 1 points 2 months ago (1 children)

Activating services is the specific task NixOS is great at, you can just add it and it downloads the packages and starts it and generates the configs

[–] traches@sh.itjust.works 2 points 2 months ago

Yeah, I’ll probably switch eventually I’m just trying to talk myself out of it because I don’t have the time to learn right now