this post was submitted on 03 Dec 2023
73 points (86.1% liked)

Linux

48078 readers
1055 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
 

I've been here a week ago already asking if Arch would be fine for a laptop used for university, as stability is a notable factor in that and I'm already using EndeavourOS at home, but now I'm curious about something else too - what about Arch vs NixOS?

I heard that NixOS is pretty solid, as due to the one file for your entire system format you can both copy and restore your system easily whenever, apart from your normal files and application configurations of course.

Are there any major downsides to NixOS compared to Arch apart from the Arch Wiki being a bit less relevant? I'd also lose access to the AUR, but admittedly I don't think I've ever actually needed it for anything, it's just nice to have. Also, since NixOS has both rolling release and static release and you can mix and match if you wanna get packages from unstable or not, I'm not losing Arch's bleeding edge, which is nice.

top 50 comments
sorted by: hot top controversial new old
[–] ani@endlesstalk.org 36 points 11 months ago* (last edited 11 months ago) (3 children)

I'd recommended Arch because with NixOS you end up having to tinker too much. Besides, if you need to use Linux for development purposes, Arch follows the usual Linux/Unix conventions, while with NixOS you would end up tinkering...And you can always use the Nix app from Arch.

Just use Arch with Gnome or KDE, that will save you a ton of time.

[–] CatLikeLemming@lemmy.blahaj.zone 17 points 11 months ago (3 children)

Huh, I never expected anyone to recommend Arch to me because you have to tinker too much with an alternative distro. I thought simplicity was the reason why people liked NixOS, no?

[–] ani@endlesstalk.org 27 points 11 months ago

Comparatively, NixOS is complex, while Arch is simple. NixOS diverges very much from traditional Linux distributions, beginning with using a diferent filesystem hierarchy, which breaks a ton of apps, requiring workarounds like patches, simulating a standard filesystem... In the long run, you will have to deal with many NixOS-specific issues.

Because you're going to Uni, it's better to focus on having a mostly just works distro with updated repository, and that's Arch. On your free time in the future, maybe try NixOS in a VM just so you have a feel for it. And again, you can use Nix on Arch so you use apps from Nixpkgs.

This all comes from an originally Arch user turned into an experienced NixOS user.

[–] Deckweiss@lemmy.world 16 points 11 months ago* (last edited 11 months ago)

I have set up my archlinux os in a weekend with btrfs snapshots and everything I need. About once a quarter I tinker with it for 30 minutes to either fix a broken update or do some custom solutions to minute problems. It has been running like this for 5years. And snapshots allow me to rollback any fuckups in 1 minute.

I tried to setup nixos twice, because I love the concept. Both times I tinkered with it for 1 to 2 weeks, had to take paid leave. At the end, some stuff still didn't work as I wanted it to. Any customization that is not already natively implemented in nix is a huge pain in the ass to add. Things that would be a 5min config edit on arch took hours on nix to make them rEpRoDuCaBLe. I have experienced no additional benefit over btrfs snapshots.

Tldr: If I could pay somebody 100$ to set up nixos just the way I want it, I'd use it. But since I have to do it in my own free time, I won't.

load more comments (1 replies)
[–] fxt_ryknow@lemmy.world 7 points 11 months ago (1 children)

I'm not sure I agree with this... I'm using nix on several different generation thinkpads, two older generation MacBooks (one air and one pro), two different older generation imacs, as well as my home built PC, and an OEM built pc.... All with little to no tinkering whatsoever.

All my tinkering was first setting nix up and figuring out how to use it... Then I saved and copied my config and use the same one on all the machines (albeit with subtle changes on first install).

I've used arch a handful of times over the years, and it is without question, significantly more "needy" over time, imo.

[–] ani@endlesstalk.org 2 points 11 months ago (1 children)

Guess you never had to package general or hard to package software like those that require fixed output derivation or undersupported ecosystems, trying to use common development environment for Python under NixOS, running binaries under NixOS, the list goes on.

[–] fxt_ryknow@lemmy.world 3 points 11 months ago (1 children)

I have not.... And in fairness to me, OP didn't mention the need for any of those things. OP mentions having not even installed anything with the AUR in Arch, which to me just means they are looking for something stable out of the box, which nix has been for me across many platforms.

[–] ani@endlesstalk.org 3 points 11 months ago

Fair point, I was mostly listing the major downsides IMO that OP asked for

[–] Kaidao@lemmy.ml 5 points 11 months ago

This is my experience as well. I went back to Arch after trying NixOS for a few weeks. I just ended up spending way too much time tinkering with the system instead of using it. Also, I feel like a major advantage to nixos is only viable if you have multiple machines. I only have a main desktop.

[–] Unmapped@lemmy.ml 26 points 11 months ago* (last edited 11 months ago) (2 children)

The downside of NixOS is bad documentation. Which makes it take quite a while to get your config setup the way you want. Its so worth it though. I used arch for 5+ years and have been on NixOS for about 6 weeks now. I'm definitely never going back. My conifg is done, I barely have to change anything now. Its all saved in a git repo so I never have to make it again. I've already switched all of my machines over. And even a few of my friends. Which has been super easy to do cause I just give them my config then remove everything they don't need. I've only been using it for a little while but it feels so reliable and Unbreakable even though I'm running unstable packages. Because if anything breaks you just go back to the last generation that worked. Which made me willing to just try anything when I was setting it up.

Also you could run Nix package manager on arch for this, but the nix package repo is amazing. It has everything i've needed or even thought about installing. And in my opinion its way better than using AUR packages. Most of the time you just DL them and don't have to build them. Its just so much faster and more reliable then using Paru or Yay. Plus there is a NUR( nix user repo) but tbh I've never even looked at it.

The other con I know of is issues running binaries and app images. But there are was work arounds for them. I use a few app-images by just running 'appimage-run '. And so far its worked perfectly. As for a binaries you can use steam-run or I think using distrobox would work. But I haven't had to do anything like that yet.

I found this YouTube channel quite useful when I was setting mine up. Vimjoyer

[–] agressivelyPassive@feddit.de 8 points 11 months ago (2 children)

I found it fairly difficult to set up nixos on one of my machines, because it simply didn't ship with a certain, relatively common kernel module/user space app. I also couldn't find a usable workaround (only compiling my own kernel on every update, which is not exactly my kind of fun).

So, you might want to try that out first.

[–] OmnipotentEntity@beehaw.org 4 points 11 months ago

Out of curiosity, which one?

[–] noli@programming.dev 2 points 11 months ago

https://nixos.wiki/wiki/Linux_kernel

You can specify custom parts of the config that enables that module and/or extra module packages.

If you specify a custom part of the config then ye sure you'll be compiling the kernel on each kernel update but you don't need to manually configure it

load more comments (1 replies)
[–] deikoepfiges_dreirad@lemmy.zip 22 points 11 months ago (1 children)

I used to like the idea of nixos because it felt "tidy" to configure everything centrally. However that tidyness is achieved by adding an extra layer which just replicates the configuration options of every program. If there is a bug in that layer or something is just not implemented, either you have to learn the whole inernals of nixos and nixpkgs, for which there is no real documentation, or you have to resort to doing things imperatively again, which is hard because of the opacity of the generated system and also defeats the whole purpose. So basically, you are completely dependent on nixos developers for things you could have easily done yourself on arch.

[–] flashgnash@lemm.ee 11 points 11 months ago

I have to disagree with this, with home-manager you can pretty much put just put your normal config files inside your NixOS config and map them into wherever they're meant to go, except now they're managed by nix

The built in config options are really nice but you don't have to use them in the slightest as long as the package itsself is in nixpkgs

[–] Presi300@lemmy.world 21 points 11 months ago (3 children)

NixOS and nix in general is incredibly complicated imo and the documentation is... let's just say sub par. I'd go with arch unless you really just wanna learn nix.

load more comments (3 replies)
[–] lupec@lemm.ee 12 points 11 months ago* (last edited 11 months ago)

As a recent NixOS convert coming from Bazzite (Kinoite/Silverblue with user friendly daily driver and gaming tweaks), and before that mostly Arch-based distros, I'd say it boils down to the tradeoff between having way more control over reproducibility and having to deep dive into the often poorly documented domain specific rabbit hole that is Nix. If you're comfortable with going out of your way to learn, looking for examples, reading source code to find out what options you can use or how stuff works, it can absolutely be worth it but it's a steep price to pay for sure.

I personally adore what Nix sets out to solve and find it extremely rewarding to learn. Plus, as a developer, I enjoy puzzling out how to get stuff done and don't mind diving into the source if I need to, so it works for me. I'd absolutely prefer solid documentation, of course, but it's not a deal breaker.

When it comes to software, the Nix repo has a staggering amount of prebuilt binaries ready to download (which you can search here) and it's often not too hard to hack together your own reproducible package if you want after you get comfortable enough with it. At least for my use cases, I haven't really missed much from my days using Arch and the AUR. If anything, I appreciate how much more consistent it tends to be in comparison.

If you, like myself, go for a flake (yet another rabbit hole within a rabbit hole) based setup and point to the unstable repo, you basically get a fully reproducible, easy to update and rollback rolling release not too dissimilar to using Arch with auto btrfs snapshots enabled. That's how I used to do Arch and it feels pretty familiar.

Anyway, that's what I got. If you have any more specific concerns or questions I'd be happy to elaborate!

Edit: I forgot to add but I find a nice way to get comfortable without fully commiting is using Nix as a package manager on any old distro. You could install it on Endeavour (I recommend this method) and play around with Home Manager, use it as a dotfiles manager on steroids, have it declaratively install and manage the CLI apps you can't live without and whatnot, see how you like it. That's how I started, I have a common HM config I've so far used with Debian at work, Ubuntu running under WSL when I'm on Windows and now NixOS itself.

[–] taanegl@beehaw.org 12 points 11 months ago* (last edited 11 months ago)

Let me put it like this: it's about learning curve. Arch is relatively easy to begin with, but NixOS gets much easier the more nix you learn.

What do I mean about that? Imagine having to patch something, which can be the thing. On arch you'd have to replace a package, which could lead to issues and conflicts, whereas NixOS gives you the option to keep two or even more versions of the same library, because it does not rely on your traditional UNIX path.

But with this super power comes a catch. You have to learn a programming language and learn how the nix store operates, which is a pretty high learning curve. Also, NixOS suffers from a governance issue and going by the documentation is like shooting in the dark.

That being said, the best manual for NixOS is GitHub, searching for anything and filtering by the nix language. You'll see a ton of varying systems, be they workstations or servers.

And no matter what all the warnings say, no, flakes aren't EXPERIMENTAL or UNSTABLE, but rather CONTENTIOUS internally. Again: I love NixOS, but they gotta fix their governance issues.

[–] dinckelman@lemmy.world 11 points 11 months ago (1 children)

I’ve been using Arch for almost 8 years, and I enjoy basically everything about it. Since Nix has been so popular lately, I thought I’d take a look at it too. I like what it does, but the documentation is really poor, and the learning curve is insanely steep. When flakes and nix-command become stable, I’ll be giving it another shot

load more comments (1 replies)
[–] BaroqueInMind@kbin.social 8 points 11 months ago* (last edited 11 months ago)

Once I found out about Paru, I decided I would no longer need another OS outside of everything Arch provides. Also, Valve decided to switch SteamOS to Arch, so I'm sticking with it once they release it.

[–] XenBad@lemmy.world 6 points 11 months ago (2 children)

I use NixOS for University and would highly recommend it if you want a highly configurable system that’s declarative, however, NixOS doesn’t have great documentation for certain features and usually does things differently, so you’ll have to learn the Nix way of doing things. On the plus side, I’ve never been unable to fix my OS when it broke, you simply rollback, or if there isn’t a suitable rollback, you can plug in a live usb and set the system to use a specific commit (can’t remember the exact command for this and that’s presuming you store your config with git). Also according to these statistics nixpkgs has more packages than the AUR.

load more comments (2 replies)
[–] hottari@lemmy.ml 5 points 11 months ago (1 children)

You can setup your Arch with grub menu btrfs snapshots just like NixOS for convenient rollbacks. NixOS has too steep a learning curve, coming from someone who recently tried it and ended up being somewhat disappointed by it. NixOS sounds good on paper but in reality it is a long way from a mature product for desktop or general use.

As you mentioned Arch has AUR which packages just about anything and everything you could ever want in the future. And the Arch Wiki will never be "not relevant" so long as you are using Linux anywhere, the Arch Wiki is a handy reference.

load more comments (1 replies)
[–] onlinepersona@programming.dev 4 points 11 months ago

NixOS's documentation is dog. It's not absolute dog, but it's dog. The learning curve is brutal.

But... the (mostly) declarative management is its strongest feature. It's very solid and you can easily unfuck you system if you haven't done stuff like mess with partitions or delete files manually.

If NixOS had better documentation and GUI to manage the system, it would be a no-brainer, but unfortunately, it is about 5-10 years away from that. The community is very top heavy, but it's easy to just do your own stuff.

[–] actual_patience@programming.dev 3 points 11 months ago

I think you are understating the value of the Arch Wiki and AUR.

I am also a university student. I was required by one of my courses to program an Arduino using ArduinoIDE. My program, however, was not detecting my Arduino. By simply scrolling the Arch wiki, I found the issue, downloaded the fix via AUR and was able to get it working hassle-free. An equivalent of this process does not exist on NixOS.

I do not know what programs your uni requires, but if you do plan on using them on Linux, Debian or Arch, or their many derivatives should be the go-to simply for documentation and quick-fixes alone.

[–] dino@discuss.tchncs.de 3 points 11 months ago

You didn't mention a single argument for why you would need a reproducible system. It sounds more like the buzz around immutable systems makes you think you are losing out on something, which is not the truth.

[–] Nibodhika@lemmy.world 3 points 11 months ago

First of all: Do you need reproductibility? I.e. having the exact same system on multiple machines? If not NixOS might be a lot more complex than what you need.

Secondly: Instability does not mean what you think it means. People read instability and think the system will break, when instability actually means your system will be updated. In the context of a server, an update can be destructive, for day-to-day users it's very rarely so.

Finally: why Arch or Nix, why not Ubuntu, Mint, Pop or any of the other dozens of distros that are usually recommended for new users?

[–] utopiah@lemmy.ml 3 points 11 months ago* (last edited 11 months ago) (2 children)

Going to sound like a boring pleb but... if your OS takes less than 1h to install and setup (which is my experience with Debian/Ubuntu on a SSD with a fiber connection, or even on a RPi with a modern microSD on an ADSL connection over WiFi) then it doesn't matter much what you use. You grab a mug of coffee, click here or there from time to time and if your /home partition is saved you are good to go faster than most people even respond to an email.

load more comments (2 replies)
[–] Nickm8@lemmy.world 3 points 11 months ago

Have you considered staying with EndeavourOS, and using Btrfs with Timeshift?

[–] Drito@sh.itjust.works 2 points 11 months ago* (last edited 11 months ago)

I encountered limitations on NixOS, as instance Ly display manager, or using an app compiled by myself. Maybe there are solution but it is not always simple. Archlinux is way more flexible. Updates can theorically breaks the system , but since one year I never broke Arch despite updates on 200+ packages.

Notice I favors minimalist graphic environments (WM that don't need updates ) and minimalists apps as much as possible, such as MPV and nsxiv. I don't fear of some keyboard shortcuts. This philosophy probably helps Arch updates. Sometimes I had problem on apps (Inkscape and Dolphin-emu), I use appimages for them. Nothing is perfect, but Arch put lighter roadblocks than NixOS.

load more comments
view more: next ›