Systemd for Developers

Systemd not only brings improvements for administrators and users, it also brings a (small) number of new APIs with it. In this blog story (which might become the first of a series) I hope to shed some light on one of the most important new APIs in systemd:

Socket Activation – In the original blog story about systemd I tried to explain why socket activation is a wonderful technology to spawn services. Let’s reiterate the background here a bit.

The basic idea of socket activation is not new. The inetd superserver was a standard component of most Linux and Unix systems since time began: instead of spawning all local Internet services already at boot, the superserver would listen on behalf of the services and whenever a connection would come in an instance of the respective service would be spawned.

This allowed relatively weak machines with few resources to offer a big variety of services at the same time. However it quickly got a reputation for being somewhat slow: since daemons would be spawned for each incoming connection a lot of time was spent on forking and initialization of the services — once for each connection, instead of once for them all.

Spawning one instance per connection was how inetd was primarily used, even though inetd actually understood another mode: on the first incoming connection it would notice this via poll() (or select()) and spawn a single instance for all future connections. (This was controllable with the wait/nowait options.)

That way the first connection would be slow to set up, but subsequent ones would be as fast as with a standalone service. In this mode inetd would work in a true on-demand mode: a service would be made available lazily when it was required. Continue reading…

Related Posts

Tahoe Least-Authority File System for secure, distributed data storage Looking for a solution to give you an edge in the ongoing struggle between you and the authorities over the privacy of your data? Then you should take...
GNOME Software preview on Fedora 20 alpha GNOME Software is one of the more exciting features that I'm looking forward to in the next release of Fedora. This is a brand new project, but the pa...
Still in search of that perfect desktop distribution The quest for perfection is an endless one. Like the quest for freedom (material or spiritual), there is always one more step. It is just the nature o...
LVM configuration on Openfiler 2.3 Openfiler is one of two free and open source NAS/SAN applications in active development (the other one is FreeNAS). By default, Openfiler is installed...
Install Cinnamon on Kali Linux Kali Linux is the next-generation edition of BackTrack. It is BackTrack reborn. However, unlike BackTrack, which has a GNOME 2 and KDE installation fl...
ProtonMail and Subrosa: Encrypted communication for the privacy-conscious ProtonMail and Subrosa are two separate communications services that's attempting to offer users a platform for secure, encrypted communication. They ...

We Recommend These Vendors and Free Offers

Launch an SSD VPS in Europe, USA, Asia & Australia on Vultr's KVM-based Cloud platform starting at $5:00/month (15 GB SSD, 768 MB of RAM).

Deploy an SSD Cloud server in 55 seconds on DigitalOcean. Built for developers and starting at $5:00/month (20 GB SSD, 512 MB of RAM).

Want to become an expert ethical hacker and penetration tester? Request your free video training course of Online Penetration Testing and Ethical Hacking

Whether you're new to Linux or are a Linux guru, you can learn a lot more about the Linux kernel by requesting your free ebook of Linux Kernel In A Nutshell.


Leave a Comment

Your email address will not be published. Required fields are marked *

*