Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: grab sockets from systemd #1141

Closed
wants to merge 1 commit into from
Closed

Conversation

steelman
Copy link

Hi, this is my first attempt to teach Radicale systemd socket activation. Comments are more than welcome.

Context

systemd can open and bind sockets (of various types and not only sockets), wait for an incoming connection and start a service when a connection appears. It is a bit like inetd but with its own protocol that allows passing multiple listening sockets. systemd can give a service a socket either before or after accept(2). This patch assumes Radicale shall receive a listening socket, call accept(2) and wait for any later incoming connections.

The patch

The protocol for grabbing open sockets is rather simple but I decided to use listen_fds() function from the systemd.daemon module anyway. The module, however, is not required for Radicale to work the old way, neither on Linux nor on any other systems. BTW launchd on macos has its own socket activation protocol and it should be possible to implement both protocols side-by-side.

When Radicale detects open sockets during startup it ignores server.hosts configuration option from the configuration file and uses the passed sockets.

I decided to implement this functionality as a separate class to give a better overview of changes required to implement it. What bugs me a bit is that I had to copy the contents of server_bind() from WSGIServer and HTTPServer to avoid binding a socket that has already been bound by systemd. Is there a better way?

Future work.

systemd doesn't mind if a service decides to exit and activates it upon next incoming connection. Radicale can exit after some time of inactivity to preserve resources on smaller systems.

@Unrud
Copy link
Collaborator

Unrud commented Mar 22, 2021

This was already implemented at some point but removed again to keep the integrated WSGI server minimalistic: 2275ba4
There are multiple WSGI servers (e.g. Gunicron or uWSGI) that support socket activation.

@pbiering pbiering added feature need:reporter feedback feedback from reporter required labels Mar 1, 2024
Copy link
Collaborator

@pbiering pbiering left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Either rebase to Radicale 3 or close PR

@pbiering pbiering added this to the 3.2.x milestone Mar 6, 2024
@pbiering pbiering modified the milestones: 3.2.x, 3.3.x Sep 23, 2024
@pbiering pbiering removed this from the 3.3.x milestone Oct 8, 2024
@pbiering
Copy link
Collaborator

pbiering commented Oct 8, 2024

closed because no further response - please reopen with a rebased PR if feature should be still implemented

@pbiering pbiering closed this Oct 8, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature need:reporter feedback feedback from reporter required
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants