Sixos: A nix OS without systemd [video]

3 months ago (media.ccc.de)

Can anybody explain to me again why systemd is so bad ? Genuinely I'm not sure anymore: It is chock full of features and it gets the job done. Since it is used in a lot of big distributions it gets a lot of fixes, updates, testing and feature improvements regularly.

Yes, it is maybe monolithic (but so is the Linux kernel). Its philosophy may differ from unix's "get one thing done well" too but integration of various functionalities comes with its benefits.

Some people say it is bloated. The substitutes to systemd are lightweight but less featureful. Maybe some of them will get bloated as they achieve feature parity.

People have a right to build substitutes and replacements -- I believe in the "Let a hundred flowers bloom" philosopy. However I can't understand why systemd is the point of so much disagreement.

  • I think this is as good a time as any to reread "The Rise of Worse is Better".

    https://www.dreamsongs.com/RiseOfWorseIsBetter.html

    The article compares the Unix/C philosophy with the Lisp philosophy and concludes that Lisp is "better" (it is The Right Thing), but that Unix/C will probably end up dominating. Obviously, he was right.

    The article is pretty famous around the suckless, minimalist, crowd. But I think everyone who reads it takes a slightly wrong lesson from that article. The point isn't that Unix/C won because it was simple. The point is that Unix/C was simple enough to use, simple enough to implement on most available hardware and that it did everything you needed it to do.

    The minimalist people have turned software simplicity into the modern version of The Right Thing, and are surprised when they found out that the "worse" (more complex) thing wins. But The Right Thing will never win. The Good Enough always wins.

    Is Linux better than *BSD? Well *BSDs are more simple, easier to understand and reason about etc. But, at least OpenBSD, doesn't have mount --bind, so I can't use it. Case closed. And I think that's the case for most people. Linux has thing X which I need so I will use Linux, even if ideologically *BSD is imo better.

    Is D-Bus The Right Thing? No; but it is The Good Enough. polkit, selinux, ACLs, and so on.

    The most recent example I can think of is Hyprland. It is basically the only viable Wayland window manager (aside from sway). Not because it is the best designed or the simplest, or anything like that. But simply because it is the only one Good Enough to use.

    SystemV init was not good enough for complex service management. systemd is. systemd simply does everything you need it to do well enough. So systemd wins. Simple as. It will only be replaced when it is no longer Good Enough.

    • Exactly, for some values of "good enough". (Unfortunately IMNSHO) Systemd cannot be toppled by all-out assault. It must be subverted. Looking forward to reimplementations and/or shims which provide the Systemd API but are reimplementations.

      Something like Wine, where in the analogy systemd is the Microsoft Win32 API and we want to be able to run systemd "enabled" software on something else. Or at least re-compile it.

      Wine also started with an incredible amount of stubs which did nothing, but that was often enough for many programs to work anyway.

      11 replies →

    • D-Bus is good enough for all sorts of things. But you absolutely don't need a behemoth like systemd to use D-Bus. A D-Bus communication option can be added to existing programs and utilities, or new ones could be fashioned for which it is a central mode of operation; and still there would have been no an ever-growing pile of centrally-maintained and inter-dependent artifacts.

      As for SystemV... as I mentioned in another comment - in hindsight, that was not the issue. There were and are SystemV alternatives [1]. One can even write one that uses D-Bus in an opt-in fashion, to foster other facilities' use of it.

      The init system excuse is very much like the stone in the fable of the stone soup: https://en.wikipedia.org/wiki/Stone_Soup - it's what gets the vagabond's foot in the door, and is the first ingredient for the soup. But actually, the stone carried no significance, and the resulting soup is pretty much the same thing as without the stone part.

      [1] : ruint, OpenRC, launchd, s6, nosh, finit, procd, upstart etc. See brief description and links at https://alternativeto.net/software/sysvinit/ for example.

      1 reply →

    • > The most recent example I can think of is Hyprland. It is basically the only viable Wayland window manager (aside from sway). Not because it is the best designed or the simplest, or anything like that. But simply because it is the only one Good Enough to use.

      I'd wager the vast majority of (non-embedded / single-purpose) Wayland deployments are gnome and KDE.

      4 replies →

  • I think a lot of the arguments I’ve seen stem from “Unix philosophy” style arguments. Also, historically the systemd project has been quite hostile to user requests in some cases, which broke existing workflows for people.

    I personally think the basic “service manager” functionality works pretty well and I like systemd overall.

    However, the same is not true for a bunch of the more peripheral services (e.g. resolved, networkd, timesyncd). What’s particularly annoying is that there exist mature open source projects that can provide better functionality in a lot of cases which could be used, rather than bundling a half-assed attempt with systemd (eg. unbound, chrony).

    • > resolved, networkd, timesyncd

      None of these are mandatory though. It's up to the distros whether to use them. For example at this point resolved is pretty commonly enabled by default, networkd not at all, and timesyncd is perhaps 50-50 with chrony.

      10 replies →

    • resolved and timesyncd are intended to be removed by the end user of the operating system. Sort of like a transparent peel is intended to be removed by the buyer of a new shiny device.

      I haven't seen anything worse than those two from systemd crowd.

      5 replies →

  • It's worth pointing out that Lennart Poettering simply rubbed some people the wrong way in his communication, and that ended up reflecting on systemd, irrespective of the software itself. (I am not making a case that this is good or bad, right or wrong. Just pointing it out.)

    • It was absolutely the way it was done and the arguments use to shut up the opposition. Then the distros all just adopted it and it was case closed and &*@#$#@ you. This happened with GNOME turning into some attempt at a tablet/phone UI and that upset enough of us to result in Cinnamon and MATE.

      You have the people who like GNOME as it is now just as people accept systemd but you might as well be talking to Mac fans - to people who have to learn to like it because they have no choice.

      Technically I think launchd might be the inspiration for systemd and for people who like the way the Mac works it's "yay" but it's not necessary.

      Anyhow, I like dinit. It's declarative with a simple config language and not a monolith - absolutely perfect.

    • some?

      Let's rephrase the question the other way: is there anyone who thinks that LP's attitude is fine?

  • > People have a right to build substitutes and replacements -- I believe in the "Let a hundred flowers bloom" philosopy.

    It's a blessing and a curse. Look at package managers, they more or less all do the same thing, with one primary job of "go download some binary so I can run it", yet there's so many to choose from. Every time you read some Linux guide they have to list 7 different ways of installing the same package. It's stupid, probably even more so for the maintainers of those packages because they have to distribute their package 7 different ways. At least I'm glad systemd has mostly become the standard, so you don't have to also see 7 different ways of creating a service.

    • Usually, it's the distributions problem to package software. You as a software developer publish documentation on how to build your application and then simply wait for other people to do the packaging for you. The creation of services is the same, you can maybe create a recommendation, but the service definition is part of the package file and thus not your problem.

      2 replies →

  • I think you answered your own question:

    > monolithic

    > It's philosophy may differ from unix's "get one thing done well"

    > it is bloated.

    Besides all this, the main issue, for me, is how it managed to spread and ingrain itself into distributions making them dependent on it.

    If you want to use an alternative to systemd on those distributions, you are usually on your own, constantly trying to fix it whenever there are breaking changes.

    It's good to have options which are simple to replace.

    > It is chock full of features and it gets the job done.

    So is Windows :)

    • >Besides all this, the main issue, for me, is how it managed to spread and ingrain itself into distributions making them dependent on it.

      I don't think the phrasing is correct. Your choice of word (spread/ingrain itself) seems to imply there is malicious intent. Software do not sneak itself into distribution by themselves. It is the other way around. Distribution creators have total freedom on what components/software they find useful to build their distributions on. If a majority of distros decided to use systemd, that mean a majority of people maintaining distributions found the positive outcomes of using systemd were worth dealing with any disadvantage it may had over using another solution.

      13 replies →

    • How it managed to spread is no surprise. Linux desktop was a complete mess with consolekit and unmaintained stuff. Then they supported cgroups which distros wanted to use and since all the unmaintained stuff didn't there wasn't a lot of options.

    • Booting up a system is a complex domain. If you randomly cut a complex domain into pieces, you will have the exact same complexity PLUS a huge amount of additional complexity for all the communication/error handling between the different parts - what other complex domain uses million tiny tools? Does chrome use curl and then pipe it into a html renderer and whatnot? Sure, there are libraries (that's a different architectural layer though with less complexity to break, and functions don't decompose arbitrarily either). The unix's philosophy is more of a sounds good on paper, and there are certain cases where it applies - it's definitely not universal.

      Also, the core of systemd is not even particularly big. People often mix into completely optional modules that run under the wider systemd project, but that's a false conclusion that "systemd eats the world".

      > How it managed to spread

      You mean that individual distributions voted/decided separately, multiple times to choose the better tool? Debian has the most democratic voting system and unanimously voted for systemd.

      And yeah, if I want to use my own display manager protocol instead of X or Wayland I would also be similarly stranded. Options are good, but standards and compatibility are just as important - a million incompatible options only give rise to chaos.

      I am, for example, very happy that Linux applications are finally not as distribution-dependent and there is a good chance to run that .deb file on anything else running systemd without much trouble. I remember the times when it was not so.

      6 replies →

    • >Besides all this, the main issue, for me, is how it managed to spread and ingrain itself into distributions making them dependent on it.

      Because it's better than the alternatives?, don't remember systemd buying distro maintainers lol

      >If you want to use an alternative to systemd on those distributions, you are usually on your own, constantly trying to fix it whenever there are breaking changes.

      Of course they aren't being paid to support everything under the sun and http://islinuxaboutchoice.com/

      >So is Windows :)

      Then use it if it's better for you

  • > Can anybody explain to me again why systemd is so bad ?

    It's huge, messy, has a poor bug and security history, obfuscates things that don't need obfuscating, and is just generally IMO not a clean or efficient implementation. It's a very Windows style solution, very different from the lean and minimal stuff I like to run generally.

    The advantages it provides are questionable, and are dwarfed by the issues it has had in the past IMO.

    OpenRC perfectly meets my needs at present and my system boots incredibly quickly. When s6 is finished that situation will only be improved.

  • I've noticed the folks who like it tend to want to get other stuff done, don't care about the details, and want things to 'just work'. The ones who don't like it seem to be the folks who do low-level stuff and have to interact with more than it's "happy path" abstractions. i.e. the ones who actually have to care how it was architected.

    • Sysadmins that have to care how the system is running and being organized behind the scenes gonna kill someone before they have to went back to bash script for system management, people who complains about systemd do it because ideological reasons, don't like LP, Unix philosophy or something, etc, or never learned it and want to argue that their mess of bash scripts, that they use solely to boot their system and nothing more, are somewhat more stable or secure

      1 reply →

  • > it gets the job done

    Except exactly the opposite is true: it is sysvinit (and derivatives) who had the job done. In a very basic way, slow and perhaps not even compatible with modern requirements and expectations, but the job was done.

    Systemd on the other hand does the job it thinks should be done, not you. Your opinion does not matter.

    You can spend however much time you want editing /etc/ssh/sshd_config and then restarting sshd and then pulling your hair out on why tf sshd ignores certain options while still definitely parsing sshd_config. Only to later find out that systemd/ubuntu crowd decided to listen on port 22 via systemd, sort of like inetd did back in the days. It's like sshd directly listening on port was not good enough for the last 30 years, definitely had to be changed. Oh yeah, and to make your life miserable, they mask the name of the listening process with "sshd" in it, so you get confused even more.

    And people can come up with countless of similar examples.

    Incredible attitude and arrogance is what makes people hate systemd.

    • I'm sure you have other examples (and I'm not really asking for them) but your sshd example would make me dislike the choices Ubuntu made, not systemd. Like I don't blame systemd for snaps being so awful.

      4 replies →

    • Sysvinit left everyone to their own ends to write their own bespoke special ways of configuring & running services. With no security options and no consistency.

      Personally I found that to be offering nothing at all & having every maintainer and sysadmin diy their services to be incredibly inefficient & waste a ton of time because every service you looked at was potentially built from a different init skeleton & modified in bespoke unique ways.

      Sysvinit offers way way way too little.

      3 replies →

  • "and it gets the job done."

    Until it doesn't. Fortunately I didn't have to debug it often, but when it was a lot of pain.

    I prefer the fs under /tmp to be tmpfs. On the BBB is wasn't. I changed that and on next reboot the system didn't come up again -- no way to log in. Why? And what to do? Turns out I failed to state the fs_freq and fs_passno fields -- those aren't optional, but while the old mount tool tolerated their absence, systemd chose to interpret the fstab strictly, failed to mount that fs, consequently didn't reach the local-fs.target and hence didn't offer any way to log-in. Unlike Raspberry Pis, the BBB doesn't offer the possibility to remove (and mount and debug elsewhere) the boot medium. Fortunately, I found help on-line on how to connect a serial terminal to the BBB and interrupt the boot process, forcing the use of /bin/sh as init process...

  • Big monolith that imposes requirements on your system and robs one of the feeling of knowing how the whole thing works?

    At least that’s me. I use systemd in most of my installs for reasons similar to yours, but nothing feels more sublime to me than installing a simple init system and a few other daemons for system features I actually use.

  • In my experience, it doesn’t get its extremely simple job done.

    I’ve tried a half dozen systemd distros. Each one hit some insane bug at some point that took a day to debug. Every single time, it was some undocumented systemd thing that has no reason for existing.

    Anyway, it’s all devuan and openbsd at home these days. I’ve had zero non-hardware related issues in over a year.

    Actually, that’s not true. Devuan still defaults to pulseaudio (the moral precursor to systemd), which still doesn’t support locking your audio output port in a way that survives reboot. It also crashes randomly when audio ports come and go. The upside is it randomly requires a reboot or moves audio out to an unconnected jack.

    I replaced it with pipewire, bringing the number of Poettering services on my machines to zero. Now things work reasonably.

    • My n=1 is that I only ever had problems with it during the "early days", now I just use it and get on with things. I can't recall the last issue I had with systemd. tbf I generally only write a few scripts and rust microservices that need to be loaded/start/stop/reload... It's simple to add them to the systemd process. The rest of the system stays out of the way. I will admit I stick to more conservative systems like Redhat and Ubuntu LTS. I guess everyone's opinion is valid on this. It's definitely kind of heavy but it's next to nothing of a load on modern systems of the past 7 or 8 years.

    • Pipewire has pulse protocol behind the scenes, so your still using his tech you just don't know about that, also I got it now, is mostly ideological thinking and no reasoning behind systemd hate, is about not using that person tech, and if you break dozen of distros messing where you shouldn't the fault is yours not the distro

    • And yet, some of us manage to successfully run critical national infrastructure on stacks that include Linux distributions running systemd.

  • I think you are beating a somewhat dead cow here. systemd wars are over. It's in most mainstream systems nowadays, but there are also lots of cool projects out there doing different things. Everything's fine, nobody wants to go into those old pro and con flame wars any more.

    • Everything is fine, unless/until many developers begin to assume systemd is present and make software ports to non-systemd Linux (or *BSD) systems prohibitively expensive.

      7 replies →

    • > systemd wars are over

      Well yes but actually no.

      With every new Ubuntu version I have to carve out new metastasis no one asked for. For example, 24.04 (or maybe even 23.10) changed the way sshd is started up - by systemd listener instead of sshd on its own like it was for decades. This way they saved a few megabytes of RAM (solely on computers that are not exposed to the internet, of course).

      While fighting against systemd-as-PID1 is futile for many years, fighting against the spread is definitely worth it.

      3 replies →

    • Fair, point taken: Some people are working on systemd replacements because they want to build some cool things in that area. Just like there are multiple programming languages and no one says "Why don't you just use Java/C++" it should be OK to work on Linux systems without systemd and not think too much of it.

    • This doesn't make sense. I, for one (transitioning to Linux usage only gradually), haven't been aware of the systemd and its criticism, and I'm grateful for the info. Then, the informed users can vote with their feet. Things change all the time, and only mass adoption/usage is what makes a given distribution to be mainstream or niche.

      So, please do continue to criticize, continue to raise awareness. That's useful.

      1 reply →

  • NixOS is great at mitigating some of systemd's sharp edges and putting its actual properties in stark relief so that they can actually be evaluated logically (and even swapped out for alternatives without having to drastically change the whole OS distribution).

    Things I do not like:

    Configuration splayed out amongst tons of tiny .ini files (this manifests in nixos by a mostly boilerplate ~10 line config burp for every service)

    Multiple dependency types including its own enable/disable system including a whole parallel configuration tree of symlinks, as opposed to the simple/standard/traditional approach of configuration being disabled by not existing.

    Network interfaces/drives/etc splayed out each into multiple services, some from concrete configuration, some implicit - seemingly to make everything visible to its uniform model.

    Complex logical model making it hard to debug it without using bespoke tools to analyze dependency graphs and whatnot.

    I'm not sitting around hating on systemd because sysvinit was also totally overwrought and obtuse, and BSD style init scripts weren't really scalable. But I get the hate. And I totally see the room for a drastically simpler init system (especially for NixOS). It's fantastic that someone finally dug in and attempted it.

  • I really also don't understand this. I started using Linux on server OS around 2010. I think this was not long before SystemD was available in Ubuntu by default. I found writing or even understanding init scripts was really difficult for me. When I first had to get a program running under SystemD it clicked immediately and it took me about 4 hours to get it run reliably and that includes learning systemd.

    I find it easier and better on so many levels!

    • Systemd is one of the most complex and difficult to understand parts of your system. Did you know it contains a virtualization manager.

      >I find it easier and better on so many levels!

      Openrc is by any possible standard easier to use. Among the reasons is that it does not include a way to create virtual machines.

      9 replies →

  • > Can anybody explain to me again why systemd is so bad ?

    it isn't, it's great. it is different, though.

    and then come in two phenomenon:

    1. people resist to change, often out of ignorance.

    2. some people tend to look at tradition and consider it just better, without much reason. "unix systems in the 80ies had shell scripts to launch system services, that's what i shall do in the 2020ies".

    > Yes, it is maybe monolithic (but so is the Linux kernel).

    it really isn't, it's largely a collection of relatively small binaries that do one thing well but they are designed to work with each other. systemd appears to be monolithic from outside, but it really isn't.

    > Maybe some of them will get bloated as they achieve feature parity.

    they will, most likely. it's easy (as a piece of software) to be lean and clean when you're doing very little (with little error checking and recovery).

    > However I can't understand why systemd is the point of so much disagreement.

    systemd was essentially pushed down everybody's throat by Red Hat when they realized it was high time to level up the boot process for the whole ecosystem. systemd made a bunch of things not only feasible (concurrency, on-demand service activation, multiple-instances of the same service running, proper log management) but so easy they're trivial.

    so 10+ years, it's definitely a net positive.

    some people are still complaining but meh, some people will complain anyway, so let them talk, whatever.

    • >> Yes, it is maybe monolithic (but so is the Linux kernel).

      > it really isn't, it's largely a collection of relatively small binaries that do one thing well but they are designed to work with each other.

      So where are all small the projects trying to replace the small parts of systemd? AFAIK there are no stable or convenient APIs in all those parts, so even though technically systemd consists if many binaries, it is monolithic.

      This is exactly what people call "forces distributions to use it", i. e., you must choose all or nothing.

      6 replies →

    • > systemd appears to be monolithic from outside, but it really isn't.

      If it looks like a duck, walks like a duck... systemd is modular solely in theory. In practice, I am grateful that I can still remove journald and resolved from current Ubuntu installs and I'm pretty sure that's not going to be possible quite soon.

      Systemd itself may be modular, but practically distros are not going to bother.

    • > 2. some people tend to look at tradition and consider it just better, without much reason. "unix systems in the 80ies had shell scripts to launch system services, that's what i shall do in the 2020ies".

      And from that the systemd crowd tend to draw the following conclusion: if something was done a certain way for decades then it is bad and should be replaced.

      2 replies →

    • >they will, most likely. it's easy (as a piece of software) to be lean and clean when you're doing very little (with little error checking and recovery).

      Why would you even begin to think that openrc would ever want to include a whole virtualization manager. Are you serious?

      >but they are designed to work with each other.

      And they are not designed to work without one another. See e.g. dbus and how hard it is to get it working on non systemd systems.

      Systemd binaries aren't drop in features.

  • Some defaults are not good for servers. For example, systemd gives up after a few tries to restart a service. This is really annoying for server administrators when they don’t know about the bad defaults.

    https://michael.stapelberg.ch/posts/2024-01-17-systemd-indef...

    • If a service fails to startup after n times, I most certainly want to take a look at it as it might as well just end up corrupting its state even more - I don't think it's a fair assumption that most errors will just go away on their own. Nonetheless, it can be configured declaratively as a single line, and as you mention, the default can be changed.

  • systemd has done nothing but make my life easier. The people still moaning about it simply haven't used it and refuse to learn.

    • Nothing makes my life easier than pulling my hair on why tf sshd listens to port 22 after editing /etc/ssh/sshd_config and restarting multiple times. Oh, of course, it's now systemd that listens to port 22, not sshd.

      Nothing makes my life easier than cleaning out crontabs of things that wake my box in the night and find out that something still gets launched. Oh yes, systemd now has timers no one asked for.

      Nothing makes my life easier than disabling a service then masking a service then masking it's sockets, then blanking files then chattr +x those files and end up having broken ubuntu instance because there are so many ways to launch a service it's not even funny at this point.

      Nothing makes my life easier than finding out multi gigabytes /var/log/journald folder that has exactly zero reasons to exist because text-based logs are still collected and properly rotated in a place where any sane person would expect them to be.

      Shall I continue or do you get the gist? :-)

      2 replies →

    • An important skill in life in general is to understand that your personal needs and requirements are not the same as everyone else's.

    • Some people may be at the other side of bell curve of "understnanding systemd on X axis" and "liking it on Y axis" of the graph. :)

  • In the last two years I have spun up new-ish, actively supported versions of ubuntu for pre-production rollout that were shipped with a systemd-resolvd that would occasionally just stop responding for no reason. Logs said nothing was wrong, process was UP and saying it is ready to do work. strace shows a hung process.

    Stuff like this is possibly where the complaints from some people begin.

    Fortunately, I can find a tracked bug that is active. New updates get pushed, as the honestly phenomenal community of people intended this process to go. But How may years have some of those people been patching bugs like this in systemd on a regular basis? Did that time have to be spent if systemd's architecture was better from the get go?

    The Trail of Bugs to get to the point we are at today has truly taken a monumental effort from MANY people. Why wasn't systemd's community doing things well "enough" from the beginning before being folded into so many OSes?

    Let's be real. From then till now they have put in hard work, in the face of huge community pushback, because someone had to do it.

    Diehards feel it felt "foisted" upon us before it was fully baked, everyone knew sysvinit was way past its prime. Put up or shut up. Plug in a different init for your OS and move on.

    But, you know, people like talking and complaining to each other. It's a very important part of solving technical problems!

    • > Diehards feel it felt "foisted" upon us before it was fully baked

      That was the minor problem. The major meta-problems are that:

      1. The baked form itself is broken. It has numerous fundamentally flawed aspects to its design (and to its existence as a project). More baking would not have helped this.

      2. It is not intended as an option, nor even just the default option - but to make more and more utilities and libraries for managing various system facilities and services become unusable and incompatible, to be taken over by systemd. It's not like foisting, say, Thunderbird instead of Evolution as the default mail client; if you don't like it, you run the other thing. Or even version X of the kernel instead of version Y of the kernel and so on.

      > everyone knew sysvinit was way past its prime

      At this point we can say with clarity that systemd has almost nothing to do with the choice of init system. You could replace the init system with any number of things - some already existing 15 years ago, some which could be developed in the mean time. In hindsight, this is an excuse and not a reason.

    • Resolvd is not part of systemd's core. Would some KDE app misbehaving be a fair criticism of the whole project?

      Also, I would be delighted to see that mythical program that requires no maintenance and just works^TM.

      Also, what does it have to do with systemd's architecture?

      4 replies →

  • >Can anybody explain to me again why systemd is so bad ?

    I only started to hate systemd when I really had to work with it in depth.

    It is hard to understand unless why people hate it if you view it from the surface. On a high level there is nothing wrong with it. If you had to write a basic unit file you could easily do so, there are just a few basic concepts and keywords you need to know to get it working. From that perspective systemd is very much like openrc, which works very much in a similar matter.

    Systemd is not bad because it is "monolithic" or because it violates some "UNIX principle" or because it is "bloated". Systemd is bad because it is made by people who have no idea what they want to make and who seem obsessed with solving every single problem they can imagine.

    Did you know that on Ubuntu your fstab is fake? It is just a file which tells systemd which mount units it should create during boot. (https://manpages.ubuntu.com/manpages/focal/en/man8/systemd-f...)

    Did you know that systemd contains an entire virtualization manager? (https://www.man7.org/linux/man-pages/man1/systemd-nspawn.1.h...)

    Did you know that you can use systemd to manage network devices? (https://www.man7.org/linux/man-pages/man5/systemd.network.5....)

    Why do these things need to be part of my init system? I can not even imagine what the answer could be.

    Systemd is an enormous C project, which has innumerable features, many of them used extremely infrequently and which wants to perform very important tasks for your OS. It has lost any focus on being an init systemd.

    People hate systemd because it is bad software and it is bad software because it has no idea what it wants to be. The systemd documentation is one of the biggest rabbit holes in computing.

    • These aren't part of the init system, they're optional components of the systemd monorepo.

      Yes I knew all of these & have used all of these optional components. And they have provided immeasurably better administration than the historical tools that purported to do these jobs before, with far more consistency & clarity about their functioning.

      Agreed that there are lots and lots of features. Buts its amazing. Oh you want to make this service secure, with temporary users & limited permissions and limits? Sure of course. Oh you want service restarting? Not perfect I agree but pretty good for me, and avoids some thundering herd problems I've seen other service managers have. There's so many things we could be doing, to make systems better, and a lot of people really are intimidated by & hate the fact that theres a much more competent cohesive system that shows such a lack with the bare bones unchanging unimproving inconsistent low-end insecure dirty past.

      1 reply →

  • > Can anybody explain to me again why systemd is so bad ?

    Mostly I seen misguided criticism from less technical people that don't understand systemd but seem to like the idea of fitting in and have identified that a certain few verbal linux users they consider to be cool hate it with passion.

    It's really dumb and boring and they often resort to just make stuff up. This thread has a bunch of such comments.

    Systemd solves countless real problems and helped linux grow in many ways.

  • The UNIX philosophy (about which there’s a book by the same name by Michael Gancarz, and which I highly recommend) Is that each tool should do one thing and do it well.

    The old school init styles, whether BSD or SysV, adhere to that philosophy.

    Systemd is a travesty. I think it was about a decade ago that there was a remotely exploitable root equivalent compromise in the system DS built in DNS resolver. And these days includes not just DNS but also privilege escalation and who knows what else

    It’s probably fine for most people and most purposes. And by fine, I mean most people can probably use it and never see a live exploited against it.

    And if you care about security, you can probably apply enough mitigating controls that it’s not gonna be a disaster for you.

    But for me, defense in depth means avoiding systems to begin with and not trying to bandit over the problems with it

  • I think OpenRC is easier to use.

    But overall, I agree on this point. Having been a Gentoo purist during Uni time, I'm now full on NixOS. NixOS has fully abstracted away any interaction I have with SystemD, so I don't think it's useful to replace it.

    • How much does it abstract it away? I'm not much of a big Linux user, and when I am, the random 99-something-something files always irritate me because it seems totally arbitrary. Does NixOS prevent you needing to writ "unit" files?

  • > I believe in the "Let a hundred flowers bloom" philosopy. However I can't understand why systemd is the point of so much disagreement.

    Your first sentence explains, to a great extent, your second. You see, systemd is designed to _prevent_ a hundred flowers from blooming. Unlike most Unix-like system components, the idea is for systemd not be an alternative replacable component, but the whole installation above the kernel. You don't choose things; you get those services and facilities which live within systemd; and those which don't - mostly won't work. That is, unless you tear out everything related to systemd. Which is difficult, since GNOME and some other packages over time have introduced dependencies on systemd, rather than on services or facilities it provides via a common protocol or interface.

    This was also how the big Debian debate exploded, causing the fork of Devuan: The "opposition" did not demand "No systemd in Debian!", but rather, that the user would be able to choose not to have systemd at all, if they so please. I am paraphrasing from memory of course, but I believe that was the gist of it.

    And the speaker in this video faced this situation.

    I am not well-versed in NixOS and certainly not in this new project, but I imagine that if the author could easily just configure NixOS not have systemd, they might not have bothered starting this project and would more likely have published some kind of recipe/how-to page on

  • It's incomprehensible. I make some changes to config files and they don't apply so I have to find whatever poorly-documented systemd thing is controlling it instead. It is taking over every important area of the operating system. Init, login, boot, it just keeps spreading. I think on other Linux systems I am better able to reason through and modify aspects of the system or fix a problem I am having.

    I have been trying out atomic Fedora and enjoying it. I like ostree, read only root, podman, building the distro from containers. I think I have had enough of systemd, though, and might move on because of it.

  • For me, it's primarily its scope. I had a system for 10 years that changed, but fundamentally worked the same. With systemd, the changes exceeded my threshold and continue to expand into something that to me, seems ugly.

    I'm not a typical example. My view is inarticulate, subjective and maybe even irrational, but I remember the system I came to love and that was Linux. My overwhelming impression with systemd is that it's not Linux and it should not be referred to as Linux or even in the context thereof. It's not evil or bad or anything but itself, but it's not Linux. In my abstract, medieval view, Linux has a soul, albeit, at times, a tormented one. Systemd exorcises this soul for me.

    Now despite me disclaiming the subjectivity and abstraction of these perceptions, I'm pretty certain there will be some hostile replies, possibly with valid points. If you're really trying to understand the creature, I suspect it's very improbable that it will happen here. There are existing strong, well written arguments both for, against, and even neutral. Definitely worth one's time if understanding is the true objective.

    For me, it's scratching a chalkboard and smells bad. It frightens me and makes me sad. It's worse than brussel sprouts and freaks me out.

    • "My overwhelming impression with systemd is that it's not Linux and it should not be referred to as Linux or even in the context thereof. "

      Yes, systemd is an init system/service handler (and a lot of related utilities) running on top of the OS kernel Linux. They are two different things working together to make an usable OS.

      2 replies →

  • Sorry, but there many people who do not like bloat, bad practicies and daily security bugs, partially because of the aformentioned bloat. If we settle this "gets the job done" mindset we are never going to improve.

  • It might be just psychological not technical.

    Humans have a natural tendency to change resistance. This tendency tends to be higher in sysadmins who are often deep into autistic spectrum.

  • Because Karen Sandler made it a hard dependency of GNOME, effectively forcing every distro to adopt it or give up GNOME. In Linux, parent processes hold dominion over all child processes, due to the way things like ptrace work. So it was a coup d'etat of the entire userspace. Then next thing you know, systemd took over the bootloader too, which gave it dominion over the kernel as well. Old school sysadmins don't like being dominated. Especially not by some useful stooge like he who shall not be named. The source code of his projects is open source in name only. Least hackable code imaginable. Almost like it's machine generated code to make the sources as opaque and inscrutable as possible. It uses binary formats to log data, exchange messages between processes, and other awful things to obfuscate its behaviors. Someone with zero gravitas shouldn't be reinventing the vision of Bell Labs and forcing their ideas on others through NGO policy changes. I'm surprised Trump hasn't signed an executive order banning it. Even the name itself, System D, expresses this arrogance, since it claims to be 100x better than UNIX System V, because D=500 and V=5 in roman numerals. Being forced to use this init system changed the workflow and daily lifestyle of every sysadmin. In one fell swoop they took an OS that's open, transparent, and owner controllable and made it into something more obtuse than Windows. And guess who the stooge works for? Microsoft! It's the sort of thing that would make people pivot their careers towards management or quit working.

    • "Because Karen Sandler made it a hard dependency of GNOME, effectively forcing every distro to adopt it or give up GNOME."

      How did she do that? Can you dig up the git commit where that happened?

      2 replies →

  • Just see `systemctl $command $unit` to discover that systemd it's not designed by sysadmins, while it's built for them. That's it's problem, like stratis/btrfs vs zfs.

    These are software designed by people who have no experience in user-centric design, they design in theory, reasoning in theory, ignoring practice.

  • SystemdD does too much and it's like a monopoly, because it's so much work to replace, it can piss you off a lot, it needs to be very shitty for you to replace it.

  • >However I can't understand why systemd is the point of so much disagreement.

    I think the simplest way to describe it is that it's a religious conflict.

    A not insignificant segment of people who develop and/or use Linux are fervent followers of POSIX philosophy, the Unix heritage, Free Open Source Software development, and the Anti-Microsoft Church (note: Poettering is a Microsoft employee).

    These people have a religious duty to hate systemd, it's essentially heresy. It's not a disagreement based on technical or even practical merits, so the conflict can't be addressed with technical debates and will continue for the foreseeable future.

    • You think you get to just declare the opinion that differs from yours invalid by calling it religious?

      Don't the holders of that opinion get to call your position equally religious?

      "not a disagreement based on technical or even practical merits" indeed, right there in the mirror.

      The first few minutes of this video absolutely articulated some perfectly technical and practical merits. So have some comments here on this hn post. I don't see how it's valid to say no one has ever produced any.

      4 replies →

    • > disagreement based on technical or even practical merits

      Philosophy can't be reasoned based on merits. Of course there are technical merits as to why systemd-as-PID1 was (not today!) an extremely good piece of software compared to sysvinit, there's no question about that. Likewise there are valid technical reasons why systemd-timesyncd should be abolished and never mentioned again.

      But how do you decide LP's attitude on merits? How do I argue with Red Hat who shoved systemd down everyone's throat?

      So yes, it's a religious question of sorts. The religion that made Unix unix.

  • The usual arguments against systemd border on religious drivel. I've seen the talk and while I very much value the work that the speaker has done I did not appreciate that the reasons for doing this are the usual vitriolic cat-v talking points.

    systemd is very good because it makes many things that the Linux kernel can do very easy. I would like to know how the people who swear against it implement features that I regularly use in systemd like socket/mount/dbus activation, services that dynamically create a user and group on activation and keep their service and temp directories private from other services, syscall filtering, user session services that start when I log into a graphical session (very useful when you have issues with your system tray's config, for example), network mounts that get mounted asynchronously only when you're using them, actual service management and restarting a service when it fails and service dependencies (which some init systems still don't do!), and so on and so forth...

    Yes you could do all of these things by composing other programs, but there is lots of value in having them all bundled together and only having to consult one resource for documentation on them, and the fact that these are all designed to work together reduces the friction that you would get by composing other "general-purpose" tools.

    On the other hand, systemd is bad because the implementation is messy, when it does fail it tends to do so in odd and obscure ways, it comes bundled with tons of components that most people won't need, and yes the fact that it's essentially the only option you're given and that it's not portable to BSDs is not very nice.

    I would encourage people to read dinit's comparison page and Chimera Linux's FAQ section on systemd for good arguments that are not fueled by religious belief as to both why systemd is valuable and in which ways it is bad.

    https://github.com/davmac314/dinit/blob/master/doc/COMPARISO...

    http://chimera-linux.org/docs/faq#what-is-the-projects-take-...

  • Here's my hot take: systemd is the best thing that happened to Linux.

    I genuinely believe it's the reason Linux has dominated the other operating systems in the server space in the past decade. As someone who manages servers I wouldn't even consider the other options in space right now, and the features systemd provides is a substantial part of that decision.

    • > I genuinely believe it's the reason Linux has dominated the other operating systems in the server space in the past decade.

      I don't think that makes sense; Linux was already completely dominant before systemd came along.

    • As a person who manages thousands of servers I genuinely fail to see systemd as anything but a problem. I can certainly see systemd on Desktop, where the environment (network, screen resolutions, peripherals) are always changing on the go, but on server where everything is more or less fixed... systemd? The worst. Unlimited source of problems.

This is pretty cool. I especially like the better encrypted boot support and that it seems to harmonize better with nixpkgs (https://discourse.nixos.org/t/sixos-a-nix-os-without-systemd...). Curious about the infusions bit.

It not having systemd seems like a bit of a distraction from all of the other stuff that has gone into it.

  • > I especially like the better encrypted boot support [...]

    For some reason I can't directly reply to transpute's comment, but it's relevant to this thread so here goes:

    > Ownerbooted sixos closes this loophole without any "trusted computing" voodoo, eliminating all unencrypted storage except for an eeprom whose hardware write-protect pin is connected to ground [...].

    Desolder the EEPROM and read the secrets - the loophole is open wide without a TPM/SEP.

    The point of TPM is supposed to be that it makes "yoink the laptop" attacks unviable even for state-level actors, while desoldering and reading the flash is trivial for a hobbyist with cheap tools and some patience.

    However this is still an enormous step forward. All of the recent attacks on secure boot chains on Windows[1] and Linux[2] are due to usage of partially-unencrypted core system components in a complex boot chain. Sixos takes the correct approach - minimise the attack surface. All it takes is to stop rejecting the "voodoo" and take what the hardware already offers.

    [1]: https://news.ycombinator.com/item?id=42733640

    • > The point of TPM is supposed to be that it makes "yoink the laptop" attacks unviable even for state-level actors

      On the contrary. TPM _is_ an attack in itself. Its result is that control lies not with you as the user but with whoever provided you with the TPM - relative to all software which uses the TPM. And if you can't avoid that kind of software, then the HW providers and the software providers have conspired against you to control your own hardware.

      1 reply →

  • You're right. The slides about infusions and the discussion at the end about them were unexpectedly the most interesting part of the talk.

  • amjoseph focused a lot on the s6-init stuff, but I really think that infusions and the way they lead to more composable system configuration is the key thing here.

    NixOS' module system works, but I don't think there's anybody who thinks it's particularly pretty or generalisable. As soon as you want to run one service twice with slightly varying config you're SOL ...

  • systemd already has encrypted boot support. I suppose when you rip something out you have to reinvent all its functions. At that point, any rational person would question the reasons for doing so.

    Like removing the transmission from a car out of spite then realizing you need a way to switch gears.

    • So removing a transmission and installing/testing/improving a new design or way to solve the problem that hasn't been popularized isn't a worthy cause? How do you think we developed the first transmission? Or the various improvements we all take for granted these days? Yes, systemd can do this, but that isn't a reason to imply developing an alternative that can do the same, albeit in a different way, is irrational.

    • > systemd already has encrypted boot support.

      It has all of those words next to a bullet point, but the implementation is quite different, and I (like the presenter and probably many many others who are clearly not you) have more confidence in a simple fuse than with systemd[1].

      [1]: https://app.opencve.io/cve/?vendor=systemd_project&product=s...

      > At that point, any rational person would question the reasons for doing so.

      That is excellent advice. The presenter has done something you clearly cannot. You should be rational, follow your own advice, and try to figure out what those reasons are (hint: some of them are actually in the video). That might take a few hours to a few weeks of reading depending on your own experiences, and that's just how life is sometimes.

      > Like removing the transmission from a car out of spite then realizing you need a way to switch gears.

      When I have a new gadget I want to produce, I'm responsible for all of the code in it, so productivity, reliability, performance, and size are important to me whether I have written the code or I have merely used it in my product. I do not understand the way these things are important to the systemd people (or even if they are important at all), so for me, systemd is off-the-table to begin with.

      Or to put it another way: I never needed a car in the first place, because I'm making boats, and I'm not starting with a car just because I like the people who made the engine. Ignoring "solved problems" can just make everything more expensive, and maybe I only know that because I've seen enough people make that mistake, but sometimes this is true.

      Keeping an open mind means allowing yourself to be convinced too.

      7 replies →

The good thing about this that it is a Nix OS without systemd, not NixOS without systemd. systemd is so well integrated in NixOS that any attempt to introduce an abstraction to make it pluggable would come with serious disadvantages.

I am all for an alternative Nix OS trying new approaches though, and sixos seems quite innovative.

Guix also does not use systemd, but its own service manager Shepherd. Edit: the author of sixos mentions it, boils down to personal preference of not liking Scheme.

It's a shame there isn't a distribution (at least that I'm aware of) which is dynamic and modular enough to allow choosing your own "process manager" at install or even on boot.

  • Artix Linux does this. Arch sans systemd, and you have a choice between openrc, runit, s6, dinit, or even some combination of the 4. Any daemon type package will have a -runit/s6/dinit/openrc variant that includes the relevant scripts/configs.

  • In a sense, nixpkgs is that.

    And AIUI that's exactly that the author refers to by "95% is nixpkgs".

    The NixOS part (the module system and modules) is in no small part integration between the init-agnostic nixpkgs and the init system (systemd).

    That's what enables this project, as well as nix-darwin (integrates with launchd) and NixBSD.

    The traditional way (pacman, apk, apt...) is for packages to carry the init files for the service they package.

As a simple linux user that recently tried nixos to power a very small server, I would say that systemd wasn't part of the issues I encountered at all. It was the confusion tooling, the documentation all over the place, and the lack of ressources on specific topics.

  • I struggled through that phase and now nixos is pretty comfortable to me. Some of the improvements in sixos are attractive, but I'm afraid to try it because it's going to be the same thing but way worse. There's no sixos community, there's just this video, a forum post or two, and the codeberg repo. That's it.

Another fork, similar to what happened with other Linux projects regarding systemd. The difference is that in NixOS and now SixOS (SexOS), things are more dramatic, and they love piling up a bunch of complex and unnecessary crap on top of Linux. :D

I have to admit I'm not a big fan of s6 - I found it very hard to understand the scripting language execline.

So in Hacker News fashion: dinit is the one I find easiest so far. It has a declarative syntax but it's not a monolith. For me it solves every thing I didn't like about SystemV and yet it's not embrace, extend, smother.

For those looking for a Linux that works like BSD, https://voidlinux.org/.

I had tried chimera-linux with dinit (on a VM with GNOME desktop) it was a good experience while it lasted and loved the TL; DR that chimera writes and it was DIY distro which was quite good like arch in it's initial days.

But now I'm back on fedora for want of packages and not being on a mainstream distro is all rainbows and unicorns until we hit the corner case or a missing package which is available only as flatpak and won't integrate with the look and feel of the desktop environment.

  • > But now I'm back on fedora for want of packages

    You'll still be off the beaten path, but you could fix this particular complaint by running Chimera and then putting nix the package manager on top of it

Why everything is inflated and bloated? It is foundational to our computer systems.* There is alternative way, functional programming, that is much harder to learn than Object-Oriented, but makes cleaner code without side effects. So Six/NixOS is very promising and going to install it when I have learned Haskell first to understand it's foundations more deeply.

* "Can programming be liberated from the von Neumann style?" https://dl.acm.org/doi/pdf/10.1145/359576.359579

  • > but makes cleaner code without side effects

    No, that is an urban legend.

    > when I have learned Haskell first to understand it's foundations more deeply

    Nix is nothing like Haskell.

    Also, the functional and lazy nature if Nix is not an ideological decision, it's a necessity when you have a giant monorepo config for 200000 packages. (Without laziness you'd have to wait for an hour just to evaluate the config options.)

Why do people insist on living in the 1980s? systemd has enabled so much missing and previously convoluted functionality. There is a small but vocal coalition of admins that refuse to learn new skills. As if we didn't have enough "systemd free" novelty distros.

If you want to live in the past, go run SunOS. You might need a dusty old tape drive, though.

  • the dismissal of systemd criticisms by saying they’re unimportant (for you) or that admins are living in the past has got to be one of the most annoying things about the topic. It devolves into a flamewar because of it, since nobody can actually engage constructively once that happens.

    I’ve laid my actual criticisms bare multiple times on this site.

    1) The tight coupling of the userland with systemd means that while systemd replaced a pleathora of inits (not just sysv): the target is now too large to be replaced even if there are better ones. Systemd is the last init linux will have, and increases the barrier to port software to other unix-likes.

    2) The non-optional/default features have been buggy and difficult to replace. Journald has no replacement; systemd-networkd is one of the most common causes of failure for my desktop due in part to being flakey when dnssec is not available.

    3) The overreliance on dbus turns the “the unix philosophy” ;) away. Text as a universal communication medium, everything is a file, etc.

    There are more, but these are my main ones. Throwing away the corpus of admin muscle memory is not an an issue anymore.

    To be blunt, I was using Fedora when systemd was coming out, I know how it works intimately because it was constantly broken. Part of what gives me pause is that I know how utterly undebugabble it is when it fails: it just hits those causes less frequently as the world is forced into using it. It becomes battle hardened.

    Oh, and the obvious criticism agains the maintainers who have been very unapologetic to bugs and undesired behaviour, in a much worse way than the Apple “you’re holding it wrong”.

    Did you ever consider that it’s also free software nerds who are the most likely to hate being told what to do?

    • > 3) The overreliance on dbus turns the “the unix philosophy” ;) away. Text as a universal communication medium, everything is a file, etc.

      have you considered the reality that the "unix philosophy" results in incredibly brittle systems? byte streams ("""plain text""") are untyped and prone to mishaps.

      3 replies →

    • > 3) The overreliance on dbus turns the “the unix philosophy” ;) away. Text as a universal communication medium, everything is a file, etc

      I prefer an introspectable, typed, and efficient communication protocol over streaming text because of the "Unix philosophy" whatever that may be.

      Is the philosophy documented somewhere or is it just in our hearts? Because the Systemd Bus interface has great docs right here: https://www.freedesktop.org/software/systemd/man/latest/org....

      3 replies →

    • > systemd-networkd is one of the most common causes of failure for my desktop due in part to being flakey when dnssec is not available.

      While I have nothing to say about your general points - I am pretty neutral to systemd, but I really dislike how it makes porting software to BSDs harder - I have one question:

      Why are you not using networkmanager on a desktop computer? I have only used networkd on a server where I needed things like MAC matching and device renaming.

      Genuinely curious. On my desktop I used a wired connection, so NM is probably overkill, but I like how I can have a tray icon to manage my VPN and wireguard connections.

      2 replies →

    • "To be blunt, I was using Fedora when systemd was coming out, I know how it works intimately because it was constantly broken. Part of what gives me pause is that I know how utterly undebugabble it is when it fails: it just hits those causes less frequently as the world is forced into using it. It becomes battle hardened."

      One of the foundations of Fedora is to be "first" and to integrate big changes like systemd before other distros. Things will break if you do that.

      3 replies →

    • In these comments I have so far seen "resistance to change from dusty admins older than tape drive mainframes," "it is religious," and "autism."

    • Without replying to specific parts, I'd like to point out that you and others bring up parallels between Systemd and closed source proprietary software shops like Apple and Windows. I view this as bad faith because Systemd should be afforded the kindness (and obviously has the user freedoms) of a fully open source work.

      There's nothing apple-esque about any of this. 'If you're unhappy fork it', is a common adage that is definitely applicable here.

      9 replies →

    • > Systemd is the last init linux will have, and increases the barrier to port software to other unix-likes.

      Why would you write portable software that has a dependency on an init system?

      > systemd-networkd is one of the most common causes of failure for my desktop

      What is objectively worse than buggy networking in systemd is having 26 different incompatible ways to configure networking in Linux.

      It is easier to settle on one method (like literally every other OS) and fix the bugs than continually come up with newer, equally buggy and broken, ways of doing it.

      8 replies →

    • Well, as far as your first point goes: Systemd has been a suite of tools instead of just an init system for a while now.

      The Linux kernel is de facto pretty tightly coupled with GNU stuff, but you don't get irate about that, so why does Systemd deserve your ire?

      3 replies →

    • > To be blunt, I was using Fedora when systemd was coming out, I know how it works intimately because it was constantly broken

      This was Fedora 15, in 2011. I would say using this as a baseline qualifies as living in the past?

      2 replies →

    • > Systemd is the last init linux will have

      I'm fine with that.

      > and increases the barrier to port software to other unix-likes.

      Don't care about "other Unix-likes", and in fact I wish they didn't exist.

      > The non-optional/default features have been buggy and difficult to replace.

      Let's not pretend as if the pre-systemd crap wasn't even more buggy.

      > The overreliance on dbus turns the “the unix philosophy” ;) away. Text as a universal communication medium, everything is a file, etc.

      Dbus is a text-based protocol based on files though. What a silly complaint.

      P.S. Dbus sucks, but thankfully it would be pretty easy to replace in systemd if somebody got sick enough of dbus.

      12 replies →

  • > Why do people insist on living in the 1980s?

    Because the music was better.

    > systemd has enabled so much missing and previously convoluted functionality.

    At the cost of much other convolutions and BLOAT.

    > If you want to live in the past, go run SunOS. You might need a dusty old tape drive, though.

    Not really, there is always http://tribblix.org/ :-) Besides that NetBSD would probably be more fun.

    Speaking of which reminds me of https://www.usenix.org/legacy/events/usenix01/freenix01/full...

    & https://mewburn.net/luke/talks/auug-2003/

    Ever heard of it?

    Btw. https://postimg.cc/CZtH4rHp

    Nao gätt off mai lawwnh!1!!