diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-11-01 17:22:55 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-11-01 17:22:55 +0000 |
commit | 57708d0d30318b096479d0c8c6d90c7ed7b6f960 (patch) | |
tree | a1635282fb8e6a057f90f8767c94e5fcea6b7143 | |
parent | 5a7510046a6fa1bda081a77f1020ce6402f4be8e (diff) | |
download | rspamd-57708d0d30318b096479d0c8c6d90c7ed7b6f960.tar.gz rspamd-57708d0d30318b096479d0c8c6d90c7ed7b6f960.zip |
Fix critical issue with fuzzy storage.
Fuzzy stroage could not save any hashes on termination due to bugged
signals handling.
Reported by: at0r at #rspamd
-rw-r--r-- | src/fuzzy_storage.c | 51 |
1 files changed, 17 insertions, 34 deletions
diff --git a/src/fuzzy_storage.c b/src/fuzzy_storage.c index 902987118..17e97d328 100644 --- a/src/fuzzy_storage.c +++ b/src/fuzzy_storage.c @@ -329,54 +329,32 @@ end: } static void -sigterm_handler (gint fd, short what, void *arg) +sigterm_handler (void *arg) { struct rspamd_worker *worker = (struct rspamd_worker *)arg; struct rspamd_fuzzy_storage_ctx *ctx; - static struct timeval tv = { - .tv_sec = 0, - .tv_usec = 0 - }; ctx = worker->ctx; - event_del (&worker->sig_ev_usr1); - event_del (&worker->sig_ev_usr2); - rspamd_mutex_lock (ctx->update_mtx); mods = ctx->max_mods + 1; - wanna_die = 1; g_cond_signal (ctx->update_cond); rspamd_mutex_unlock (ctx->update_mtx); - - (void)event_base_loopexit (ctx->ev_base, &tv); } /* * Config reload is designed by sending sigusr to active workers and pending shutdown of them */ static void -sigusr2_handler (gint fd, short what, void *arg) +sigusr2_handler (void *arg) { struct rspamd_worker *worker = (struct rspamd_worker *)arg; - /* Do not accept new connections, preparing to end worker's process */ - struct timeval tv; struct rspamd_fuzzy_storage_ctx *ctx; ctx = worker->ctx; - tv.tv_sec = 0; - tv.tv_usec = 0; - event_del (&worker->sig_ev_usr1); - event_del (&worker->sig_ev_usr2); - rspamd_worker_stop_accept (worker); - msg_info ("worker's shutdown is pending in %d sec", SOFT_SHUTDOWN_TIME); rspamd_mutex_lock (ctx->update_mtx); mods = ctx->max_mods + 1; - wanna_die = 1; g_cond_signal (ctx->update_cond); rspamd_mutex_unlock (ctx->update_mtx); - - event_base_loopexit (ctx->ev_base, &tv); - return; } static gboolean @@ -1003,9 +981,9 @@ init_fuzzy (struct rspamd_config *cfg) void start_fuzzy (struct rspamd_worker *worker) { - struct event sev; struct rspamd_fuzzy_storage_ctx *ctx = worker->ctx; GError *err = NULL; + struct rspamd_worker_signal_handler *sigh; gint i; ctx->ev_base = rspamd_prepare_worker (worker, @@ -1014,15 +992,20 @@ start_fuzzy (struct rspamd_worker *worker) server_stat = worker->srv->stat; /* Custom SIGUSR2 handler */ - event_del (&worker->sig_ev_usr2); - signal_set (&worker->sig_ev_usr2, SIGUSR2, sigusr2_handler, - (void *) worker); - event_base_set (ctx->ev_base, &worker->sig_ev_usr2); - signal_add (&worker->sig_ev_usr2, NULL); - - signal_set (&sev, SIGTERM, sigterm_handler, (void *)worker); - event_base_set (ctx->ev_base, &sev); - signal_add (&sev, NULL); + sigh = g_hash_table_lookup (worker->signal_events, GINT_TO_POINTER (SIGUSR2)); + sigh->post_handler = sigusr2_handler; + sigh->handler_data = worker; + + /* Sync on termination */ + sigh = g_hash_table_lookup (worker->signal_events, GINT_TO_POINTER (SIGTERM)); + sigh->post_handler = sigterm_handler; + sigh->handler_data = worker; + sigh = g_hash_table_lookup (worker->signal_events, GINT_TO_POINTER (SIGINT)); + sigh->post_handler = sigterm_handler; + sigh->handler_data = worker; + sigh = g_hash_table_lookup (worker->signal_events, GINT_TO_POINTER (SIGHUP)); + sigh->post_handler = sigterm_handler; + sigh->handler_data = worker; if (ctx->strict_hash) { static_hash = g_hash_table_new_full (rspamd_str_hash, rspamd_str_equal, |