this post was submitted on 19 Apr 2024
888 points (98.7% liked)

linuxmemes

21836 readers
1004 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 users for any reason. This includes using blanket terms, like "every user of thing".
  • Don't get baited into back-and-forth insults. We are not animals.
  • 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, <loves/tolerates/hates> systemd, 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 remove France.

    founded 2 years ago
    MODERATORS
     
    you are viewing a single comment's thread
    view the rest of the comments
    [–] Lmaydev@programming.dev 119 points 9 months ago (4 children)

    The idea as far as I can tell is that it's responsible for too many things and gives a massive point of failure.

    [–] rmuk 204 points 9 months ago (3 children)

    Man, wait until these people hear about the filesystem and kernel.

    [–] ThrowawayPermanente@sh.itjust.works 63 points 9 months ago (1 children)

    The very existence of a defined kernel is an insult to the Linux philosophy

    [–] psud@lemmy.world 14 points 9 months ago

    The Linux kernel (the part that gives Linux the name) is antithetical to Linux philosophy? I could understand it being contrary to GNU philosophy

    [–] Jumuta@sh.itjust.works 25 points 9 months ago (2 children)
    [–] BeardedGingerWonder 30 points 9 months ago (1 children)
    [–] Gork@lemm.ee 11 points 9 months ago

    yes mr stallman

    [–] radiant_bloom@lemm.ee 4 points 9 months ago (3 children)

    Does it ? I thought it was never completed !

    On the other hand, if you want a microkernel that does exist, there’s Mach. But I don’t think you can replace Linux with it 😆

    [–] frezik@midwest.social 16 points 9 months ago

    It's been two years away for the last 30 years.

    [–] psud@lemmy.world 4 points 9 months ago (1 children)

    Yeah, there's a Debian implementation of GNU/hurd. Debian recommend you run it in a VM

    [–] rmuk 4 points 9 months ago

    I won't bother. Sounds like hurd work.

    [–] mexicancartel@lemmy.dbzer0.com 2 points 9 months ago

    Hurd is supposed to work with GNU mach afaik

    [–] qjkxbmwvz@startrek.website 20 points 9 months ago

    In some ways I think the filesystem is philosophically the exact opposite of systemd


    I can boot my system with an ext4 root, with a btrfs /home...or vice versa. Or add some ZFS, or whatever. The filesystem is (with the exception of some special backup schemes) largely independent of the rest of the system, despite being of core importance.

    On the other hand, I can't change my init system (i.e., systemd) without serious, serious work.

    [–] ricecake@sh.itjust.works 65 points 9 months ago (2 children)

    It's also "infectious" software. The way systemd positions itself on the system, it can make it more difficult for software to be written in an agnostic way. This isn't all software, and is often more of a complaint by lower level software, like desktop environments.
    https://catfox.life/2024/01/05/systemd-through-the-eyes-of-a-musl-distribution-maintainer/ This isn't a terrible summary of some of the aspects of it.

    Another aspect is that when it was first developed, the lead on the project was exceptionally hostile to anyone who didn't immediately agree that systemd definitely should take over most of the system, often criticizing people who pointed out bugs or questionable design decisions as being afraid of change or relics of the past.
    It's more of a social reason, but if people feel like the developer of a tool they're forced to use doesn't even respect their concerns, they're going to start rejecting the tool.

    [–] snake_case_lover@lemmy.world 35 points 9 months ago (3 children)

    What do you expect from an init system? It's like saying my cpu is infectious because my computer depends on it

    [–] ricecake@sh.itjust.works 36 points 9 months ago (3 children)

    It's that it also decided to take over log management, event management, networking, DNS resolution, etc, etc.

    If it were just an init system that would be perfectly portable. People were able to write software that way with sysv for years.

    It's that in order to do certain low level tasks on a systemd system, you need to integrate with systemd, not just "be started by it". Now if a distro wants that piece of software, it needs to use systemd, and other pieces of software that want to be on that distro need to implement integration with systemd.

    A dependency isn't infectious, but a dependency you can't easily swap out is, particularly if it's positioned near the base of a dependency tree.

    Almost all of my software can run on x86 or arm without any issues beyond changing compiler targets. It's closer to how it's tricky to port software between Mac and Linux, or Linux and BSD. Targeting one platform entails significant, potentially prohibitive, effort to support another, despite them all being ostensibly compatible unix like systems.

    [–] Vilian@lemmy.ca 3 points 9 months ago* (last edited 9 months ago) (1 children)

    log management, event management, networking, DNS resolution

    and this is a bad thing? the distro can choose to not use it, but because every systemd distro uses it, it's a 1000x easier to implement it without needing to put a fuck tons of if-else's for every distro

    [–] ricecake@sh.itjust.works 13 points 9 months ago (1 children)

    No, not everyone thinks it's a bad thing. It is, however, infectious, which is a reason some people don't like it.

    Knowing why people dislike something isn't the same as thinking it's the worst thing ever, and liking something doesn't mean you can't acknowledge it's defects.

    I think it's a net benefit, but that it would be better if they had limited the scope of the project a bit, rather than trying to put everything in the unit system.

    [–] Vilian@lemmy.ca -4 points 9 months ago

    and what's the problem?, it's not like everything is in the same binary or it's a monstrosity that can't be used without using every single feature, it's a project that just has different programs under the same project name, because no one wanted todo theoe programs

    [–] radiant_bloom@lemm.ee 2 points 9 months ago

    That’s why I personally try very hard to only rely on POSIX stuff, even when it’s massively inconvenient. The only thing I haven’t gotten around to replacing yet is GNU make.

    [–] nick@midwest.social -4 points 9 months ago

    Bro I’m with you on this but the systemd bots will just keep arguing with and downvoting you. Don’t bother.

    [–] bjoern_tantau@swg-empire.de 18 points 9 months ago (1 children)

    I think the init system is the best part of systemd. It is sooo easy to use. You don't have to write the same complicated shell script for your software like everyone else. You just give systemd the path to your executable and that's basically it. It does the rest and you don't have to worry about PID files or forking the actual software. Systemd basically runs it like you did while developing it.

    I think what people don't like are all the other parts of systemd that seem to be tightly coupled. I don't know if it is even possible to run just the systemd init without any other systemd package.

    The last time I got angry at systemd was when resolvd did some DNS shit I did not approve of.

    [–] hisbaan@lemm.ee 3 points 9 months ago

    I may be wrong but I believe that all of the systemd programs are decoupled. You can run the systemd init system without any resolved or networkd. They just happen to be used by default on a lot of distros.

    [–] Deckweiss@lemmy.world 4 points 9 months ago* (last edited 9 months ago) (1 children)

    I expect it to not run a stop job for 90 seconds by default every time I want to quickly shut down my laptop. /s

    [–] snake_case_lover@lemmy.world 12 points 9 months ago (1 children)

    it doesn't run a job it waits for your jobs to end. You can set the default want time. Its the same thing on windows that asks programs to close before shutting down. If a critical application got stuck systemd has nothing to do with it

    [–] Deckweiss@lemmy.world 3 points 9 months ago* (last edited 9 months ago) (1 children)

    I know what it is. But it literally says "A stop job is running" and since english is not my first language, I had no good idea how to better express the technicalities of it in a short sentence.

    As for it having nothing to do with systemd:

    I am dual booting arch and artix, because I am currently in the middle of transitioning. I have the exact same packages on both installs (+ some extra openrc packages on artix).

    • About 30% of the shutdowns on arch do the stop job thing. It happens randomly without any changes being done by me between the sessions.

    • 0% of the shutdowns on artix take more than 5 seconds.

    I know that I can configure it. But why is 90 seconds a default? It is utterly unreasonable. You cite windows doing it, but compare it instead to mac, which has extremely fast powerups and shutdowns.

    And back to the technicalities, openrc doesn't say "a stop job is running", so who runs the stop job if not systemd?

    [–] MartianSands@sh.itjust.works 8 points 9 months ago (1 children)

    The question you should be asking is what's wrong with that job which is causing it to run for long enough that the timeout has to kill it.

    Systemd isn't the problem here, all it's doing is making it easy to find out what process is slowing down your shutdown, and making sure it doesn't stall forever

    [–] Vilian@lemmy.ca 0 points 9 months ago (1 children)

    the develope receive a fuck ton of hate too, and he keep the project going, against every one unix-way haters

    [–] ricecake@sh.itjust.works 6 points 9 months ago

    Well, I don't give him too much credit for that given that it was his day job, not some passion project.

    Most of the hate towards him was because he took an abrasive stance against anyone who disagreed with him, or pointed out bugs.

    [–] Pacmanlives@lemmy.world 6 points 9 months ago

    Indeed, the Unix philosophy was do one thing and do it well. ls just list directory’s and files it’s not a network manager too. Systemd crams a lot of extra shit into an init.d/rc.

    I still prefer the old system-v/openRC setup or BSD’s setup. It’s simple does 1 job and does it well. But I can work with systemd just fine in creating scripts these days and it does have some nice features like user startup scripts baked into it and podman integrates very nicely with it.

    [–] possiblylinux127@lemmy.zip 3 points 9 months ago

    It isn't though, systemd is broken into smaller parts.