• Robert Haas's avatar
    Eliminate one background-worker-related flag variable. · d0410d66
    Robert Haas authored
    Teach sigusr1_handler() to use the same test for whether a worker
    might need to be started as ServerLoop().  Aside from being perhaps
    a bit simpler, this prevents a potentially-unbounded delay when
    starting a background worker.  On some platforms, select() doesn't
    return when interrupted by a signal, but is instead restarted,
    including a reset of the timeout to the originally-requested value.
    If signals arrive often enough, but no connection requests arrive,
    sigusr1_handler() will be executed repeatedly, but the body of
    ServerLoop() won't be reached.  This change ensures that, even in
    that case, background workers will eventually get launched.
    
    This is far from a perfect fix; really, we need select() to return
    control to ServerLoop() after an interrupt, either via the self-pipe
    trick or some other mechanism.  But that's going to require more
    work and discussion, so let's do this for now to at least mitigate
    the damage.
    
    Per investigation of test_shm_mq failures on buildfarm member anole.
    d0410d66
postmaster.c 165 KB