mod_posix: Move POSIX signal handling into util.startup to avoid race

When libunbound is initialized, it spawns a thread to work in.
In case a module initializes libunbound, e.g. by triggering a s2s
connection, Prosody would not handle signals, instead immediately quit
on e.g. the reload (SIGHUP) signal. Likely because the libunbound thread
would not have inherited the signal mask from the main Prosody thread.

Thanks Menel, riau and franck-x for reporting and help narrowing down
This commit is contained in:
Kim Alvefur 2024-03-02 13:23:24 +01:00
parent ed0188ce81
commit 3036a689fa
2 changed files with 43 additions and 50 deletions

View file

@ -15,10 +15,6 @@ if pposix._VERSION ~= want_pposix_version then
.. "Perhaps you need to recompile?", tostring(pposix._VERSION), want_pposix_version);
end
local have_signal, signal = pcall(require, "prosody.util.signal");
if not have_signal then
module:log("warn", "Couldn't load signal library, won't respond to SIGTERM");
end
local lfs = require "lfs";
local stat = lfs.attributes;
@ -124,49 +120,3 @@ else
end
module:hook("server-stopped", remove_pidfile);
-- Set signal handlers
if have_signal then
module:add_timer(0, function ()
signal.signal("SIGTERM", function ()
module:log("warn", "Received SIGTERM");
prosody.main_thread:run(function ()
prosody.unlock_globals();
prosody.shutdown("Received SIGTERM");
prosody.lock_globals();
end);
end);
signal.signal("SIGHUP", function ()
module:log("info", "Received SIGHUP");
prosody.main_thread:run(function ()
prosody.reload_config();
end);
-- this also reloads logging
end);
signal.signal("SIGINT", function ()
module:log("info", "Received SIGINT");
prosody.main_thread:run(function ()
prosody.unlock_globals();
prosody.shutdown("Received SIGINT");
prosody.lock_globals();
end);
end);
signal.signal("SIGUSR1", function ()
module:log("info", "Received SIGUSR1");
module:fire_event("signal/SIGUSR1");
end);
signal.signal("SIGUSR2", function ()
module:log("info", "Received SIGUSR2");
module:fire_event("signal/SIGUSR2");
end);
end);
end
-- For other modules to reference
features = {
signal_events = true;
};