BUG/MEDIUM: threads: don't close the thread waker pipe if not init

This bugfix concerns the thread deinit but affects the master process.

When the master process falls in wait mode (it fails to reload the
configuration), it launches the deinit_pollers_per_thread and close the
thread waker pipe. It closes rd (-1) and wr (0).

Closing a FD in the master can have several sides effects and the
process will probably quit at some point.

In this case it assigns 0 to the socketpair of a worker during the next
correct reload, and then closes the socketpair once it falls in wait
mode again. The worker assumes that the master died and leaves.
This commit is contained in:
William Lallemand 2018-12-15 22:34:31 +01:00 committed by Willy Tarreau
parent a648399c90
commit 808e1b7c40

View File

@ -503,8 +503,15 @@ static void deinit_pollers_per_thread()
{
free(fd_updt);
fd_updt = NULL;
close(poller_rd_pipe);
close(poller_wr_pipe[tid]);
/* rd and wr are init at the same place, but only rd is init to -1, so
we rely to rd to close. */
if (poller_rd_pipe > -1) {
close(poller_rd_pipe);
poller_rd_pipe = -1;
close(poller_wr_pipe[tid]);
poller_wr_pipe[tid] = -1;
}
}
/*