From 46dc1ca76114bff925460aee9439fc7dbef1185f Mon Sep 17 00:00:00 2001 From: Willy Tarreau Date: Fri, 1 May 2015 18:32:13 +0200 Subject: [PATCH] MEDIUM: peers: unregister peers that were never started The peers initialization sequence is a bit complex, they're attached to stick-tables and initialized very early in the boot process. When we fork, if some must not start, it's too late to find them. Instead, simply add a guard in their respective tasks to stop them once they want to start. --- src/peers.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/peers.c b/src/peers.c index d39898a574..59f934d780 100644 --- a/src/peers.c +++ b/src/peers.c @@ -1204,6 +1204,15 @@ static struct task *process_peer_sync(struct task * task) task->expire = TICK_ETERNITY; + if (!st->sessions->peer->peers->peers_fe) { + /* this one was never started, kill it */ + signal_unregister_handler(st->sighandler); + st->table->sync_task = NULL; + task_delete(st->sync_task); + task_free(st->sync_task); + return NULL; + } + if (!stopping) { /* Normal case (not soft stop)*/ if (((st->flags & SHTABLE_RESYNC_STATEMASK) == SHTABLE_RESYNC_FROMLOCAL) && -- 2.39.5