BUG/MEDIUM: queues: Make sure we call process_srv_queue() when leaving
authorOlivier Houchard <ohouchard@haproxy.com>
Fri, 13 Dec 2024 17:11:05 +0000 (17:11 +0000)
committerChristopher Faulet <cfaulet@haproxy.com>
Thu, 9 Jan 2025 09:28:04 +0000 (10:28 +0100)
In stream_free(), make sure we call process_srv_queue() each time we
call sess_change_server(), otherwise a server may end up not dequeuing
any stream when it could do so. In some extreme cases it could lead to
an infinite loop, as the server would appear to be available, as its
"served" parameter would be < maxconn, but would end up not being used,
as there are elements still in its queue.

This should be backported up to 2.6.

(cherry picked from commit dc9ce9c26469e00ab71fe6387dbd13010d4930f0)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
(cherry picked from commit 1385e4ca16b3797b0091a959b626935cd7f29b38)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>

src/stream.c

index 72d0f37..1a801b2 100644 (file)
@@ -624,11 +624,14 @@ void stream_free(struct stream *s)
        }
 
        if (unlikely(s->srv_conn)) {
+               struct server *oldsrv = s->srv_conn;
                /* the stream still has a reserved slot on a server, but
                 * it should normally be only the same as the one above,
                 * so this should not happen in fact.
                 */
                sess_change_server(s, NULL);
+               if (may_dequeue_tasks(oldsrv, s->be))
+                       process_srv_queue(oldsrv);
        }
 
        /* We may still be present in the buffer wait queue */