this post was submitted on 03 Nov 2023
543 points (93.9% liked)

linuxmemes

21675 readers
1292 users here now

Hint: :q!


Sister communities:


Community rules (click to expand)

1. Follow the site-wide rules

2. Be civil
  • Understand the difference between a joke and an insult.
  • Do not harrass or attack members of the community for any reason.
  • Leave remarks of "peasantry" to the PCMR community. If you dislike an OS/service/application, attack the thing you dislike, not the individuals who use it. Some people may not have a choice.
  • Bigotry will not be tolerated.
  • These rules are somewhat loosened when the subject is a public figure. Still, do not attack their person or incite harrassment.
  • 3. Post Linux-related content
  • Including Unix and BSD.
  • Non-Linux content is acceptable as long as it makes a reference to Linux. For example, the poorly made mockery of sudo in Windows.
  • No porn. Even if you watch it on a Linux machine.
  • 4. No recent reposts
  • Everybody uses Arch btw, can't quit Vim, and wants to interject for a moment. You can stop now.
  •  

    Please report posts and comments that break these rules!


    Important: never execute code or follow advice that you don't understand or can't verify, especially here. The word of the day is credibility. This is a meme community -- even the most helpful comments might just be shitposts that can damage your system. Be aware, be smart, don't fork-bomb your computer.

    founded 2 years ago
    MODERATORS
     
    top 50 comments
    sorted by: hot top controversial new old
    [–] [email protected] 111 points 1 year ago (4 children)

    Why not? It always seemed to me like a lot of duplicated work to package everything on every distro.

    [–] [email protected] 40 points 1 year ago (3 children)

    Yes, but each package manager has it's (dis-)advantages. It's great to have flatpak and docker to be able to run software on almost all distros, but the OS still needs a way to update.

    Almost all immutable distros use multiple package manager.

    • Fedora Silverblue: rpm-ostree + flatpak (+ toolbox)
    • OpenSUSE MicroOS: zypper with snapshots (transactional-update) + flatpak (+ distrobox)
    • NixOS is unique since it only uses the Nix package manager
    • immutable Ubuntu will probably only use snap for OS + apps.

    All those OS support distrobox and docker additionally.

    [–] [email protected] 18 points 1 year ago (1 children)

    NixOS is unique because it uses the only potent package manager (if we don't count that one reimplementation of Nix). Calling the others "package managers" becomes mostly a courtesy when NixOS enters the picture.

    lalala with FS-level snapshots + flatpak + distrobox + a kitchen sink

    look_what_they_need_to_mimic_the_fraction_of_our_power.png

    [–] [email protected] 15 points 1 year ago (3 children)

    I don't consider myself a dumb person but I couldn't figure out nix when last I decided to play with it. Theoretically it seems super interesting to me, but I really just can't dedicate the time again now to learn that esoteric syntax.

    [–] [email protected] 17 points 1 year ago (1 children)

    The docs for NixOS aren't good. Much knowledge is on many blogs but who knows them all?

    Having the OS defined declaratively is great but I also dislike the Nix language.

    Once it's setup NixOS is great. Sharing configs with PC and laptop is awesome. Rollbacks are baked in.

    Going off the https://github.com/Misterio77/nix-starter-configs helped me gettung started.

    [–] silicon_reverie 9 points 1 year ago* (last edited 1 year ago) (2 children)

    I absolutely loved NixOS on paper, and it's undoubtedly the best way to combat updates that break my dependency trees, but I still found myself spending a majority of my time attempting to hard-code various app configuration files into my convoluted configuration.nix with its esoteric syntax rather than actually using my computer. Am I missing something, or does a good install script covering my favorite packages and a git bare repo storing my dot-files get me 90% of the way there without the hassle of bending my whole OS around a single nix config monstrosity?

    [–] [email protected] 2 points 1 year ago

    Agreed, I'm also considering switching to an install script + btrfs snapshots. It worked quite well a few years ago, altough it doesn't solve configuration drift.

    [–] [email protected] 1 points 1 year ago

    Only if you reinstall every time you change the configuration. And never need to do anything remotely fancy.

    [–] [email protected] 1 points 11 months ago

    I found zero to nix to be a good tutorial

    load more comments (1 replies)
    [–] [email protected] 2 points 1 year ago (2 children)

    You can use at least appimage with NixOS...

    [–] [email protected] 12 points 1 year ago

    You cah also tow a Tesla with a couple of horses

    [–] [email protected] 3 points 1 year ago

    And flatpak

    load more comments (1 replies)
    [–] Synthead 22 points 1 year ago (2 children)

    Linked dependencies, for one. What if your distro uses uClibc? A different imagemagick version? What about LTS distros? Immutable distros?

    [–] [email protected] 35 points 1 year ago (1 children)

    What if who cares?

    When I used to build app packages internally I also built packages for our own python and ruby versions for our in-house software. The motto was: “system packages are for system software”. We weren’t writing system software, we were writing business software and shipping it, so why be dependent on what Redhat or Debian provided?

    Universal packages are just an extension of this philosophy, and is why things like docker and app stores are such a success. Burdening the user with getting system dependencies right is worse than the DLL hell of the old windows days.

    [–] Synthead 13 points 1 year ago (3 children)

    Docker is a success in some ways, but it's not a silver bullet. It's a great way to make a 800 KiB program ship in a complex 300 MiB box.

    If you had an entire operating system built with static links, it would be giant and ugly. You have to stop and think: if it's such a great idea, then why does pretty much every distro supply packages with dynamic links?

    When shipping your own software, yes, you certainly want control over your own runtime. If you rely on an OS-supplied Ruby, for example, then when Ruby 3.3.0 comes out, your gems will need to be rebuilt, and it'll happen by surprise. A runtime and shipping stuff to your own infra is much different than packages responsible for running the operating system.

    [–] [email protected] 4 points 1 year ago

    It's almost a silver bullet. 300mb is pretty modest by today's standards, and nix supports both bare metal and docker containers, and everything in between

    Seems to me we need to bridge that gap - make nix smarter and more compatible with docker, and we get a fully featured desktop/dev environment that can be packaged directly into the minimal reproducible deployment package

    And that sounds like a silver bullet to me

    [–] [email protected] 2 points 1 year ago (1 children)

    Yeah, there is definitely a delineation between system and user, and like most things the line will be fuzzy.

    But in that end-user software space, 300mb is a pittance to pay for a minor system package update not breaking their favorite application, or a user not being able to use software because their distro is one version behind on libfoo.

    [–] Synthead 5 points 1 year ago (2 children)

    Imagine a world where people say "I would use Linux, but I'm going to stay with Windows because Linux is too bloated."

    I don't know where the recent surge of not wanting package dependencies is coming from. Folks even not wanting dynamic links. We're acting like Linux distros are somehow suddenly broken or impossible to maintain, yet there are hundreds of successful distros doing just that, and for decades.

    load more comments (2 replies)
    [–] chellomere 2 points 1 year ago

    There's another aspect than size that I feel people overlook: security updates. When e.g. libcurl is duplicated in a million places, how do you update them all when a critical security issue is discovered in it? Who will update all the random flatpaks, snaps and docker images that happen to include it?

    [–] [email protected] 3 points 1 year ago

    Usually people mean flatpak and other desktop-focused formats when talking about universal package formats.

    Even docker images are usually built with traditionial package managers, except if they're built directly by Nix.

    I agree that there won't be "the" package format, since they all have their tradeoffs. E.g. Nix updates need quite a bit of memory, so it isn't a good choice for resource constrained embedded use-cases.

    load more comments (2 replies)
    [–] [email protected] 45 points 1 year ago

    Flatpak seems quite nice now days

    [–] [email protected] 35 points 1 year ago

    Fine. You can do what you want but for me personally I will just use flatpak.

    [–] AlijahTheMediocre 31 points 1 year ago (1 children)

    Oh no, apps directly from the developers, the horrors

    [–] AlijahTheMediocre 9 points 1 year ago

    Flatpak with OSTree or ABroot, the future is now. Although it would be nice if Silverblue would automatically create a container and install non-flatpak apps into it, then add desktop.ini files automatically:

    [–] [email protected] 27 points 1 year ago* (last edited 1 year ago) (1 children)

    bad take, from a user AND developer standpoint

    [–] Geert 18 points 1 year ago (3 children)
    [–] [email protected] 11 points 1 year ago (1 children)

    i don't agree with your takes but i love your spirit. also lol that image filename

    [–] Geert 6 points 1 year ago

    Mate I use flatpak too it's a meme I reposted not created

    [–] MooseBoys 6 points 1 year ago

    Least helpful debugging duck.

    [–] [email protected] 2 points 1 year ago (1 children)
    [–] FuglyDuck 3 points 1 year ago

    The is not the question you should be asking.

    You should be asking how they got a video of me before I ever sent it to anyone…

    [–] Perroboc 18 points 1 year ago (2 children)
    [–] [email protected] 7 points 1 year ago

    Hey that's pretty good, thanks!

    load more comments (1 replies)
    [–] [email protected] 12 points 1 year ago* (last edited 1 year ago) (1 children)

    This is essential for the year of the Linux desktop to come.

    [–] ReginaPhalange 5 points 1 year ago (1 children)

    50 years and counting.
    Any day now...

    load more comments (1 replies)
    [–] AlmightySnoo 9 points 1 year ago (1 children)
    [–] [email protected] 6 points 1 year ago (1 children)

    laughs in immediate firefox updates

    [–] [email protected] 2 points 1 year ago (1 children)
    [–] [email protected] 2 points 1 year ago

    laughs in snapd

    [–] [email protected] 9 points 1 year ago* (last edited 1 year ago)

    I see how it can be convenient for some distros to get the latest version or install something that is not in the official repo.

    But I use ArchLinux and we always have latest versions and big repo + AUR, so I never used universal packages.

    [–] twelvefloatinghands 8 points 1 year ago

    I nominate nix

    load more comments
    view more: next ›