this post was submitted on 13 Apr 2024
229 points (84.6% liked)

linuxmemes

21197 readers
228 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!

    founded 1 year ago
    MODERATORS
     

    Credit for the answer used in the right panel: https://serverfault.com/a/841150

    top 50 comments
    sorted by: hot top controversial new old
    [–] [email protected] 5 points 6 months ago (2 children)

    Is it r-unit, or run-it?

    I've read it as r-unit for so long and now I've only just realised that run-it makes far more sense

    [–] [email protected] 3 points 6 months ago

    lol I've been pronouncing nginx as "enn-jinx" for so long before I learned that it was "engine-ex".

    [–] [email protected] 3 points 6 months ago

    Someone is asking the important questions

    [–] [email protected] 0 points 6 months ago

    Runit, making systems easily pwnable since 2004 🎉

    • Step 1: Make a system service run as root
    • Step 2: Give service a runlevel that starts it at boot
    • Step 3: Make the file modifiable by a normal user
    • Step 4: ???
    • Step 5: pwned

    Wow much philosopy. Is great. Incredible chievement. Very pressive!

    Anti Commercial-AI license

    [–] [email protected] 11 points 6 months ago (2 children)

    I'm using Debian without ever having been involved in the init-wars. What's wrong with Systemd and why should i not use it?

    [–] [email protected] 3 points 6 months ago* (last edited 6 months ago)

    If you've never had a reason to not use it, then it's fine to continue using it. Systemd has been shown to be more or less stable, fast, and secure. The reason I don't like it is because it makes simple things really complicated. Some examples:

    • The meme
    • u/[email protected] example with sshd
    • Distros that use systemd init also seems to prefer using other systemd components as well. So you can get caught in weird situations where one task is spread across two different systems (e.g. systemd timers vs cron, systemd-elogind vs acpid)

    If none of these sound familiar, then switching to a non-systemd distro likely won't make your life easier. But if you do, then it might be worth considering.

    [–] [email protected] 4 points 6 months ago (1 children)

    I'd like to know too, a ELI5 version if possible. Somethingsomething monolithic, but what does that actually mean for me as an end user?

    [–] [email protected] 9 points 6 months ago (1 children)

    In my personal opinion, correct me if I'm wrong:

    Systemd was created to replace the init system, then through extreme scope creep took over way more than wanted and needed, the main developer was "problematic" to say it politically correct, and in practice it has over complicated many super easy tasks to the point that I hate it. Other init systems were intuitive, systemd is all but.

    Few weeks ago I setup a systemd server ssh server. Changing the port would be 5 seconds in changing a line in the sshd config, but now with the new and improved systemd I need to follow some nightmare documentation into creating systemd files in unrelated places and reload configs or something and I'm done with it

    [–] [email protected] -1 points 6 months ago (1 children)

    Gonna be honest, never heard of running before this. Briefly considered switching before OPs presentation in the comments turned me off. I don't want to associate with his/ her mind of weirdo, they aren't fun.

    [–] [email protected] 1 points 6 months ago (1 children)

    What on earth did I do to offend you this much?

    [–] [email protected] 2 points 6 months ago* (last edited 6 months ago) (1 children)

    Were you not being serious when you were calling people systemd-bots?

    [–] [email protected] 1 points 6 months ago* (last edited 6 months ago) (1 children)

    I was being serious, but I'm not calling everyone who uses sytemd a bot. It has its merits, I use it on my homeserver (NixOS). When I say "systemd bot" I mean "people who blindly dismiss valid criticism of systemd". Same as when some people say "russian bot" they mean "troll who is paid to advocate for the actions of russian government", and not "everyone from russia is a bot".

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

    Fair enough. Can't say I know enough to really decide what is or isn't valid criticism.

    [–] [email protected] 1 points 6 months ago (1 children)

    Thanks for posting your original comment btw, now that I read over my own comments I do realise that it comes across as very hostile and a little silly, regardless of intention.

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

    No, thank you for being so reasonable.

    [–] [email protected] 3 points 6 months ago

    I'm not yet convinced that "violating the unix philosophy" is a bad thing. I'm not saying that it's not, I don't have a defined opinion about this yet

    [–] [email protected] -5 points 6 months ago (1 children)

    systemd is for the weak. red hat and lennart are just shit.

    [–] [email protected] -1 points 6 months ago* (last edited 6 months ago) (1 children)

    I don't support calling people who volunteer their time to develop free software "just shit", but I can't help but agree at least a little bit about redhat. Redhat is kind of like Richard Nixon: if you just assume that eveything you dislike is their fault, you would be right surprisingly often.

    • "Predictable" interface naming
    • avahi
    • dbus

    That being said, they did also contribute to a lot of kickass software, from btrfs to Firefox to linux namespaces to qemu to pipewire, as well as to software that you can't really live without like glibc or gdb. So I guess the converse also holds: if you just assume that everything you like is there thanks to redhat, you would be correct pretty often as well. Can't really say that about Nixon though.

    [–] [email protected] -2 points 6 months ago

    hitler built the autobahn. enough to not call him shit? doubt that.

    what lennart and red hat have done is just terrible.

    [–] [email protected] 2 points 6 months ago

    Guys I only used SystemD and I didn’t know you could use anything else lol stop hating I never had any problems!

    [–] [email protected] 24 points 6 months ago

    Big news (from 2017): debian held back software features because someone doesn't like the new way of doing things. Let's blame systemd for this unprecedented case.

    What's wrong with giving access to the specific sudo command, as suggested in the other answers?

    [–] [email protected] 86 points 6 months ago (2 children)

    When you hate something so much you have to find weird corner cases to support your views. Even then the way described isn’t how someone who knows that they are doing would do.

    The best way for an unprivileged user to manage a service is for that user to run it. That way you inherit the correct permissions / acls / selinux contexts.

    The command to do so is:

    systemctl --user start the_service.service

    [–] [email protected] 11 points 6 months ago* (last edited 6 months ago) (3 children)

    What if multiple users have to manage that service?

    Edit: nvrmnd, pretty sure the runnit solution won't allow this either, your answer is correct. What about while the service is already running? Wouldn't your solution require a restart?

    [–] [email protected] 4 points 6 months ago* (last edited 6 months ago)

    A generic stack overflow answer:

    Do you REALLY need multiple users to manage that service? Maybe it's better to have multiple instances of that service and.... (This goes on and on)

    [–] [email protected] 5 points 6 months ago* (last edited 6 months ago)

    pretty sure the runnit solution won’t allow this either

    I'm no expert, but I think you could make a special group, set the supervise directory to be owned by that group, and add all relevant users to that group? Either way, as I explained in a different reply, running the service as a user vs letting that user control a root service are completely different things, and one is not always a substitute for the other.

    [–] [email protected] 12 points 6 months ago (1 children)

    If the service is already running it has to be stopped as a system service and run as a user service. In order to ensure that the service inherits all the correct permissions / acls / se linux policies the service needs to be launched from the limited permissions context.

    With the systemd approach you’re not just passing a control handle around. You’re ensuring the process is running under an appropriate security context.

    If you want to let multiple users manage the user systems service, I would probably go with sudo and systemd user files. You could create a group which has sudo access etc. The important idea is that an unprivileged user controls an unprivileged service.

    [–] [email protected] 3 points 6 months ago

    With the systemd approach

    What about this makes it "the systemd approach"? runit supports user services too. These are just two different tasks that are needed in different contexts. Sometimes what you need is to "pass a control handle around" to a privileged service. And sometimes you need to actually make a service unprivileged.

    [–] [email protected] 6 points 6 months ago* (last edited 6 months ago) (2 children)

    I'm out of the loop. The answer that references "one person's personal opinion" is from 2017, and the context it links to is from 2016. Surely things have changed since then, right?

    .. Right?

    (I'm genuinely asking, I've got no idea)

    Edit: I just checked on Linux Mint 21.3. It's still on the same version as back then, 0.105. Well, Debian is nothing if not sable!

    [–] [email protected] 3 points 6 months ago (1 children)

    Bookworm looks to be on version 122, so as downstream distros update to newer Debian versions, it should be updated now

    [–] [email protected] 1 points 6 months ago (1 children)

    Mint 21.3 is based on Debian Bookworm (via Ubuntu 22.04, not counting LMDE of course). I don't know what you're looking at and I also don't fully know how this works, but what you said doesn't seem to be the case.

    [–] [email protected] 2 points 6 months ago* (last edited 6 months ago) (1 children)

    Ubuntu 22.04 is long before Bookworm

    It looks like Ubuntu pulled in Bookworm’s version in 23.10

    If Mint is sticking to LTS Ubuntu versions, it will get it whenever it rebases on top of Ubuntu 24.04

    Edit: Debian (Bookworm) polkitd version 122: https://packages.debian.org/bookworm/polkitd

    Ubuntu 22.04 polkitd version 105: https://packages.ubuntu.com/jammy/polkitd

    Ubuntu 24.04 pre-release polkitd version 124: https://packages.ubuntu.com/noble/polkitd

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

    Very well, you seem to definitely know this stuff better than me! I based my comment on this answer and getting this myself on Mint 21.3:

    $ cat /etc/debian_version 
    bookworm/sid
    

    But reading a bit closer, I think this is the key part:

    That's how, for example, Ubuntu 20.04, released in April 2020, can be based on Debian 11 "Bullseye", which was released in August 2021.

    So Ubuntu probably pulled Bookworm before it was released, and before it upgraded policykit. But it's still to some extent based on Bookworm. Does that sound right?

    [–] [email protected] 3 points 6 months ago* (last edited 6 months ago)

    Yeah, Ubuntu pulls in the development version of Debian

    “Sid” is the unstable name for Debian - where packages are being tested for the next release

    Debian Bookworm was released 2023

    Ubuntu LTS and Debian have tended to release on a two year cadence offset by a year

    • Debian Stretch (2017)
    • Ubuntu 18.04 (2018)
    • Debian Buster (2019)
    • Ubuntu 20.04 (2020)
    • Debian Bullseye (2021)
    • Ubuntu 22.04 (2022)
    • Debian Bookworm (2023)
    • Ubuntu 24.04 (2024)
    [–] [email protected] 1 points 6 months ago

    lol, I didn't even attempt to read the full thing. But now you made me curious.

    But only curious. I don't feel smart enough to read and comprehend the entire thing.

    load more comments
    view more: next ›