mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-01-06 20:29:48 +00:00
MINOR: session: define flag to explicitely release listener on free
When a session is allocated for a FE connection, session_free() is responsible to call listener_release() to decrement listener connection counters and resume listening. Until now, <listener> member of session was tested inside session_free() before invocating listener_release(). To highlight more explicitely the relation between sessions and listeners, introduce a new flag SESS_FL_RELEASE_LI. Only session with such flag set will invoke listener_release() on their cleanup. Flag is set inside session_accept_fd() on success. This patch has no functional change. However, it will be useful to implement session creation for rHTTP preconnect.
This commit is contained in:
parent
808daa7cfb
commit
45b80aed70
@ -39,6 +39,7 @@
|
|||||||
enum {
|
enum {
|
||||||
SESS_FL_NONE = 0x00000000, /* nothing */
|
SESS_FL_NONE = 0x00000000, /* nothing */
|
||||||
SESS_FL_PREFER_LAST = 0x00000001, /* NTML authent, we should reuse last conn */
|
SESS_FL_PREFER_LAST = 0x00000001, /* NTML authent, we should reuse last conn */
|
||||||
|
SESS_FL_RELEASE_LI = 0x00000002, /* session responsible to decrement listener counters on release */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* max number of idle server connections kept attached to a session */
|
/* max number of idle server connections kept attached to a session */
|
||||||
|
@ -78,8 +78,12 @@ void session_free(struct session *sess)
|
|||||||
struct connection *conn, *conn_back;
|
struct connection *conn, *conn_back;
|
||||||
struct sess_priv_conns *pconns, *pconns_back;
|
struct sess_priv_conns *pconns, *pconns_back;
|
||||||
|
|
||||||
if (sess->listener)
|
if (sess->flags & SESS_FL_RELEASE_LI) {
|
||||||
|
/* listener must be set for session used to account FE conns. */
|
||||||
|
BUG_ON(!sess->listener);
|
||||||
listener_release(sess->listener);
|
listener_release(sess->listener);
|
||||||
|
}
|
||||||
|
|
||||||
session_store_counters(sess);
|
session_store_counters(sess);
|
||||||
pool_free(pool_head_stk_ctr, sess->stkctr);
|
pool_free(pool_head_stk_ctr, sess->stkctr);
|
||||||
vars_prune_per_sess(&sess->vars);
|
vars_prune_per_sess(&sess->vars);
|
||||||
@ -285,12 +289,19 @@ int session_accept_fd(struct connection *cli_conn)
|
|||||||
sess->task->process = session_expire_embryonic;
|
sess->task->process = session_expire_embryonic;
|
||||||
sess->task->expire = tick_add_ifset(now_ms, timeout);
|
sess->task->expire = tick_add_ifset(now_ms, timeout);
|
||||||
task_queue(sess->task);
|
task_queue(sess->task);
|
||||||
|
|
||||||
|
/* Session is responsible to decrement listener conns counters. */
|
||||||
|
sess->flags |= SESS_FL_RELEASE_LI;
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* OK let's complete stream initialization since there is no handshake */
|
/* OK let's complete stream initialization since there is no handshake */
|
||||||
if (conn_complete_session(cli_conn) >= 0)
|
if (conn_complete_session(cli_conn) >= 0) {
|
||||||
|
/* Session is responsible to decrement listener conns counters. */
|
||||||
|
sess->flags |= SESS_FL_RELEASE_LI;
|
||||||
return 1;
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* if we reach here we have deliberately decided not to keep this
|
/* if we reach here we have deliberately decided not to keep this
|
||||||
* session (e.g. tcp-request rule), so that's not an error we should
|
* session (e.g. tcp-request rule), so that's not an error we should
|
||||||
@ -300,9 +311,9 @@ int session_accept_fd(struct connection *cli_conn)
|
|||||||
|
|
||||||
/* error unrolling */
|
/* error unrolling */
|
||||||
out_free_sess:
|
out_free_sess:
|
||||||
/* prevent call to listener_release during session_free. It will be
|
/* SESS_FL_RELEASE_LI must not be set here as listener_release() is
|
||||||
* done below, for all errors. */
|
* called manually for all errors.
|
||||||
sess->listener = NULL;
|
*/
|
||||||
session_free(sess);
|
session_free(sess);
|
||||||
|
|
||||||
out_free_conn:
|
out_free_conn:
|
||||||
|
Loading…
Reference in New Issue
Block a user