Someone please convince me why I should hate systemd because I still don’t understand why all the hate exists.
The idea as far as I can tell is that it’s responsible for too many things and gives a massive point of failure.
Man, wait until these people hear about the filesystem and kernel.
The very existence of a defined kernel is an insult to the Linux philosophy
The Linux kernel (the part that gives Linux the name) is antithetical to Linux philosophy? I could understand it being contrary to GNU philosophy
hurd “exists”
That’s GNU/Hurd thank you
yes mr stallman
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 😆
It’s been two years away for the last 30 years.
Yeah, there’s a Debian implementation of GNU/hurd. Debian recommend you run it in a VM
I won’t bother. Sounds like hurd work.
Hurd is supposed to work with GNU mach afaik
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.
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.What do you expect from an init system? It’s like saying my cpu is infectious because my computer depends on it
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.
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
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.
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
Bro I’m with you on this but the systemd bots will just keep arguing with and downvoting you. Don’t bother.
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.
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.
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.
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
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
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?
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
-
the develope receive a fuck ton of hate too, and he keep the project going, against every one unix-way haters
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.
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.
It isn’t though, systemd is broken into smaller parts.
My understanding is that some people are die hards to the software philosophy of “do one thing really well”. systemd at the very least does many different things. These people would prefer to chain a bunch of smaller programs together to replicate the same functionality of systemd since every program in the chain fits the philosophy of “does one thing really well”.
For me it’s 3 things
- Do one thing and do it well
- Everything is a file in Linux
- human readable logs
Systemd breaks all three of though by being monolithic and binary. It actually makes you have to jump through more hoops to do things in certain cases. I understand it’s a mindset shift but it really starts making it feel more like Windows with how it works and the registry and event log.
I don’t see how systemd has anything like the Windows registry. At least its journals are leagues ahead of Windows event logs, I hate those things and the awful viewer they have.
like Windows
systemd-bsod is incoming
You forgot: use as many dependencies as you need. For example, my init system does not use
xz-utils
.
It’s different from what the init system was like in the 80’s.
I don’t hate systemd. However:
Units and service files are confusing, and the documentation could be a lot better.
That said, when systemd came out the traditional init stack was largely abandoned. Thanks to systemd (and the hatred of it) there are now a couple of traditional-style init systems in active development.
Damn systemd is LGPL and not GPL? Another reason to hate lol
I don’t hate it now, though I did when it first came out, as it borked my system on several occasions. I’m still not a fan, but it works so eh.
One borkage was that the behavior of fstab changed, so if there was e.g. a USB drive in fstab which was not connected at startup, the system would refuse to boot without some (previously not required) flags in fstab. This is not a big deal for a personal laptop, but for my headless server, was a real pain. The systemd behavior is arguably the right one, but it broke systems in the process. Which is somewhat antithetical to, say, Linus Torvalds’ approach to kernel development (“do not break user space”).
It also changed the default behavior of
halt
— now, it changed it to the “correct” behavior, but again…it broke/adversely affected existing usage patterns, even if it was ultimately in the right.In addition to all of this, binary logs are very un-UNIXy, and the monolithic/do-everything model feels more like Windows than *NIX.
Systemd came out over 10 years ago
Because
systemd tries to unify a Wild West situation where everyone, their crazy uncle, and their shotgun-dual-wielding Grandma has a different set of boot-time scripts. Instead of custom 200-line shell scripts now you have a standard simple syntax that takes 5 minutes to learn.
Downside is now certain complicated stuff that was 1 line need multiple files worth of workarounds to work. Additionally, any custom scripts need to be rewritten as a systemd service (assuming you don’t use the compat mode).
People are angry that it’s not the same as before and they need to rewrite any custom tweaks they have. It’s like learning to drive manual for years, wonder why the heck there is a need for auto, then realizing nobody is producing manual cars anymore.
There is also the argument that it’s more complicated under the hood and harder to troubleshoot, particularly because of it’s inherent parallelism and dependency-tree design, whereas initv was inherently serial. It was much more straightforward to pick the order in which services started and shut down on an initv system.
For example, say I write a service and I want it to always be the first service stopped during a shutdown, and I want all other services to wait for it to stop before shutting down. That was trivial to do on an initv system, it’s basically impossible on systemd.
For those wondering, yes I did run into this situation. My solution was clobbering the shutdown, poweroff, and restart binaries with scripts earlier in path search that stop my service, verify that they’re stopped, and then hook back to systemd to do the power event.
I had numerous situations where systemd didn’t let me abort a hanging service startup during boot or stop during shutdown.
So what do I do now, systemd? Wait till infinity??
That never happened while using other init systems. Because they simply fail properly (“sorry I did my best to stop this, I needed a SIGKILL finally”). Or simply let me log in: “sorry, some services failed to start and now it’s a huge mess, but at least you can log in and fix it.”.
I remember the clusterfuck that existed before systemd, so I love systemd.
Ever seen a log file be a binary file, not text?
Ever seen an init system that was also cron?
Do you want to be forced to use a specific init system in order to use udev?
Then SystemD is for you!
deleted by creator
Systemd came out before some people were even born
I always thought it was because it was Linux only and wasn’t usable on FreeBSD.
“I am a new linux user. After 15 minutes of research on google, I found a few forum posts and some niche websites that said SystemD was bad, so I took it as gospel. Now my system doesn’t work as simply as it did with installer defaults? How do I make everything Just Work™ after removing any OS components I don’t understand the need for?”
Linus tech tips, is that you?
He is less technically inclined
He read a prompt asking if he wanted to remove his system and said yes
Then complained about it
To be fair it was caused by installing steam. Why System76 didn’t test that I don’t know.
Its partial fault on all sides that added up.
Ubuntu shipped with that issue for some time and fixed it after some time.
Pop os iso on the download page contained it.
The package came from ubuntu but this issue was not visible since up to date pop os does not have this issue. Only the version in iso. So Pop os too made some mistake.
Linus tried to install steam. The installer does not allow removing necessary packages. He tried to install anyway ignoring all warnings, in cli.
It says if you are so sure, type “Yes, Do as I say!” with all cases and punctuation correct. Why would you be required to type a very specific phrase to install steam? Its a clear warning for confirmation. He too makes mistake by ignoring all warnings.
Not to blame anyone but all of them did partial mistake that added up
Almost like linus had agenda to oblige to
Or like the good old days where you deleted COMMAND.COM
Just delete the kernel and boot loader
Classic Chesterton’s fence principle.
It’s the linux equivalent of deleting system32.
He uninstalled systemd, now his computer is not doing systemd things anymore by his retelling. Seems like it worked fine. Yet he asks for a solution of a problem. Maybe he needs to state the problem.
This is like the Linux equivalent of deleting system32
Nah, more like deleting explorer.exe.
There’s isn’t really a Windows equivalent for this, as Windows doesn’t give you control on this level.
It’d be as if you could delete services.msc but also the runner behind it.
I did delete explorer.exe on an earlier iteration of Windows (possibly 98SE). I’ve just restored it with Windows Commander (now TCMD).
I don’t think you’ll get a cli if you delete system32.
I think we sound test that.
For skyense.
But system32 contains the NT kernel as well, so that’s worse. Uninstalling your init system on a Linux distro still leaves you with single user mode. You could probably reinstall an init system from there.
On Debian you can actually change init systems. Don’t know how hard it is and you are probably meant to install a new one after removing systemd, but it is possible at least.
I mean, it can work out if he installs an alternative init & rc and a wifi-manager first. And then recreates initrd. Maybe needs to migrate some dns stuff too.
deleted by creator
Smartest systemd hater.
deleted by creator
They forgot that heart transplant requires replacing the removed heart with another one and then connecting the blood vessels before closing up.
You can’t just take it out and say “I’ll put in another one after dinner”
Maybe they knew, but wanted to see what would happen.
Then post about how horribly complicated Linux is.
You greatly overestimate the intelligence of the average Stack Exchange question asker.
I removed and sold the wheels of my car, now it does not move.
I removed the transmission from my car but now it won’t drive
That’s what you get for transphobia my dude
he fuckin got me there
It’s like saying automatic transmission is worse than manual transmission.
Best way to fix that is to go back in time and not do that
Sudo snapper rollback…oh he’s on debian. nvm
Snapper works on all distros with BTRFS
Sure but not as default install
All these files are backed up in /System32 folder
Seeing it with a forward slash is just weird.
Windows hss supported slashes in both directions for a very long time. I almost exclusively use forward slashes to reduce mental load when switching between OSes.
Sadly not for UNC paths. Those open as if it’s a webpage.
Removed by mod
Sell computer, return to monke
Lol this reminds me of a time when I had KDE desktop environment installed on vanilla ubuntu. I thought I didn’t really need ubuntu’s default desktop environment and decided to ‘purge’ it. I quickly realized my f up when it deleted so many packages and ui started to act weird, I copied the shell’s output to a file just incase, and sure enough I couldn’t login with ui on next reboot. I was somehow able to login to shell and with some awk magic I was able to parse the text file to get all the packages I deleted and lo and behold everything worked just fine. Linux let’s you f’up your OS but it also let’s you fix it, it’s just a skill issue.
Linux let’s you f’up your OS but it also let’s you fix it, it’s just a skill issue.
Yeah, there’s something about Linux that makes me feel like if something breaks in it, the only reason I can’t fix it personally is because I lack the skills to fix the problem. Just feels nice, really.
deleted by creator
- Linux lets* you
- also lets* you fix it
It’s no tits
If your installing, or deleting something and your package manager is modifying more then a few packages: stop, read and think about what your about to do.
I updated my sources.list to something non-existing at some point and run
sudo apt update && sudo apt dist-upgrade -y && sudo apt autoremove
once and it also basically uninstalled everything. But that didn’t even matter, I popped in a recovery disk and could reinstall everything. Pretty great to be able to do all that with Linux, fuck everything up in an instant but after a few hours everything is back againWell you could have saved those hours if you were on one of those restrictive OSs. I mean why would anyone even wanna do that? /s
Now remove the rest of the OS; it’s bloat.
Who needs that pesky kernel and bloated bootloader anyway?
Refuse computers, go back to Abacus
That’s a bit much, perhaps though they should use a real mode OS
Why shackle yourself to a physical object? Just use your brain!
Arch?
Arch?
How the fuck is login and “the command line” still working? Maybe they did not reboot.
The reboot probably sent him straight to a virtual console.
I was curious too, so I tried it in a virtual machine
It half installed sysvinit, systemd failed to get fully removed, and apt gave up due to too many post-install errors
The reboot threw me into an init that asked for me to specify the runlevel (since there wasn’t anything in init.d)
I guess they didn’t understand the difference between that question and a logged in shell
My guess before trying it was that they somehow got stuck in Grub’s shell
Yeah i remember debian installs sysvinit if you apt remove systemd and installs systemd if you apt remove sysvinit
haha why does debian bother adding this rule if the system will be left in broken state anyway
Maybe because its still not a broken state? They could still add init files ig
(As the tester above) It is a broken state
It failed to install the
initscripts
package because apt bailed outapt —fix-broken install
got you a little closer, but the screenshot didn’t say they tried thatMy bet is this worked when systemd was first introduced, but since there’s not much use for it now, and sysvinit is deprecated, it just doesn’t accidentally work anymore
I mean you still can use cli? So you can technically make an init file and boot?
You can’t - it’s just asking what runlevel to launch, and there are no files for any runlevel
You’d need to add init=/bin/sh through grub at that point
As long as you can run
vim
,gcc
andmake
, it’s not broken.
initramfs recovery shell or they are trolling
Just install Devuan.
Devuan GNU+Linux is a fork of Debian without systemd that allows users to reclaim control over their system by avoiding unnecessary entanglements and ensuring Init Freedom.
Gotta love this linux rhetoric, man! It’s so out there.
I don’t want to be in control of starting up all the services during boot.
I want the init system to do that.You don’t want it until something fails. SystemD often doesn’t let you log in to fix it. It just shows a “infinitely bouncing asterisk” and hopes it will magically get better.
laughs in Gentoo
Or install MX and have both systemd and sysvinit instead of having systemd packages banned.
Systemd is bloat
/s because people think I’m serious
Operating systems are bloat.
Just give me a magnet, a needle and an hd platter
C-x M-c M-butterfly
Honestly this part of the XKCD meme never sat right with me. No self respecting emacs person would ever bind a command to C-x M-c
Meta after Ctrl rubs me the same way languages that use Subject Object Verb order do.
Like, you can do it, but it feels icky.
Also, you’ve gone to the trouble of creating a ‘butterfly’ key. Just use that.
No self respecting person would use Emacs.
Someone’s feeling that Emacs envy…
It’s a lovely OS no doubt, but I just want an editor.
No self respecting emacs person would ever bind a command to C-x M-c
A magnetized needle? Perfectly fine.
Butterflies causing cosmic rays to precisely flip bits? Don’t see anything wrong with that.
A syntactically and ergonomically incorrect Emacs shortcut? Now that’s going too much! Nobody would ever use that instead of M-x butterflies.
You need a magnet, a needle AND a HD platter?
Screens are bloat. Give me a real tty
Are you guys using your eyes?? Clearly bloat