]> Sergey Matveev's repositories - public-inbox.git/commit
examples/*@.service: sockets MUST be NonBlocking
authorEric Wong <e@80x24.org>
Sun, 30 Jun 2019 07:11:00 +0000 (07:11 +0000)
committerEric Wong <e@80x24.org>
Sun, 30 Jun 2019 07:11:00 +0000 (07:11 +0000)
commit0ea8f5dacfb6d6bfba4dd4be86416bdd2dc5907d
treec405fc00e790c8bdc90b1b94b24c7c03dca8e3a9
parent97c346050509758b5d5152f6ff1e0b0f8d871954
examples/*@.service: sockets MUST be NonBlocking

For users running multiple (-nntpd@1, -nntpd@2) instances of
either -httpd or -nntpd via systemd to implement zero-downtime
restarts; it's possible for a listen socket to become blocking
for a moment during an accept syscall and cause a daemons to
get stuck in a blocking accept() during
PublicInbox::Listener::event_step (event_read in previous
versions).

Since O_NONBLOCK is a file description flag, systemd clearing
O_NONBLOCK momentarily (before PublicInbox::Listener::new
re-enables it) creates a window for another instance of our
daemon to get stuck in accept().

cf. systemd.service(5)
examples/public-inbox-httpd@.service
examples/public-inbox-nntpd@.service
examples/unsubscribe-psgi@.service