Date: Sat, 15 Feb 2020 09:12:38 -0500 From: Greg Veldman <freebsd@gregv.net> To: Vincent DEFERT <20.100@defert.com> Cc: freebsd-questions@freebsd.org Subject: Re: Technological advantages over Linux Message-ID: <20200215141238.GY1879@aurora.gregv.net> In-Reply-To: <fde4cbec-efa0-de36-18f9-696e5cdfea3d@defert.com> References: <mailman.19358.1581761921.21074.freebsd-questions@freebsd.org> <fde4cbec-efa0-de36-18f9-696e5cdfea3d@defert.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sat, Feb 15, 2020 at 12:23:37PM +0100, Vincent DEFERT wrote: > IMO, the real problem with systemd has nothing to do with the supposed > mental disorder affecting its developer, but with the fact that systemd > control the behavior of all system services and this is what has made me > look for alternatives to Linux. The insanity of systemd is a large part of what convinced me to migrate all my personal machines from GNU/Linux to FreeBSD a couple of years ago. I use the term insanity loosely, to cover everything from certain design decisions to how the change was implemented on several popular distros... > A very concrete example: the DHCP client of a machine doesn't behave the > same way with or without systemd. When run without systemd (e.g under > Devuan), the DHCP client honors all the features described in the > standard. When run under the control of systemd (e.g under Debian), it > just takes the IP address, netmask and gateway from the DHCP server. > > Simply stated, the behavior of a machine under the control of systemd is > no longer predictable, you have to forget standards and RFCs and learn > the systemd way. Here's another concrete example: just yesterday I spent literally three hours debugging a post action hook function in a popular PHP application. This function was, at the end of processing a record, supposed to update certain data relating to that record into a PostgreSQL database. Everything worked exactly as it was supposed to when running all the steps individually by hand, but when run through the production webserver environment it simply refused to fire. After much poking around, I figured out that a recent update to the system changed the systemd unit file for the php-fpm process to set PrivateTmp=true, which was causing the prod environment to no longer be able to see the PostgreSQL socket which lived in /tmp (the real /tmp). I know of no words to fully describe the magnitude of this facepalm, which was foisted upon me with no notice or warning as part of applying routine patches to the operating system. -- Greg Veldman freebsd@gregv.net
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20200215141238.GY1879>