BUG/MAJOR: muxes: Use the HTX mode to find the best mux for HTTP proxies only

Since the commit 1d2b586cd ("MAJOR: htx: Enable the HTX mode by default for all
proxies"), the HTX is enabled by default for all proxies, HTTP and TCP, but also
CLI and HEALTH proxies. But when the best mux is retrieved, only HTTP and TCP
modes are checked. If the TCP mode is not explicitly set, it is considered as an
HTTP proxy. It is an hidden bug introduced when the option "http-use-htx" was
added. It has no effect until the commit 1d2b586cd. But now, when a stats socket
is created for the master process, the mux h1 is installed on all incoming
connections to the CLI proxy, leading to segfaults because HTX operations are
performed on raw buffers.

So to fix the buf, when a mux is installed, all proxies are considered as TCP
proxies, except HTTP ones. This way, CLI and HEALTH proxies will be handled as
TCP proxies.

This patch must be backported to 1.9 although it has no effect. It is safer to
not keep hidden bugs.
This commit is contained in:
Christopher Faulet 2019-04-24 15:01:22 +02:00
parent 274ba67862
commit c1918d1a8f

View File

@ -1098,12 +1098,10 @@ static inline int conn_install_mux_fe(struct connection *conn, void *ctx)
int alpn_len = 0; int alpn_len = 0;
int mode; int mode;
if (bind_conf->frontend->mode == PR_MODE_TCP) if (bind_conf->frontend->mode == PR_MODE_HTTP)
mode = PROTO_MODE_TCP; mode = ((bind_conf->frontend->options2 & PR_O2_USE_HTX) ? PROTO_MODE_HTX : PROTO_MODE_HTTP);
else if (bind_conf->frontend->options2 & PR_O2_USE_HTX)
mode = PROTO_MODE_HTX;
else else
mode = PROTO_MODE_HTTP; mode = PROTO_MODE_TCP;
conn_get_alpn(conn, &alpn_str, &alpn_len); conn_get_alpn(conn, &alpn_str, &alpn_len);
mux_proto = ist2(alpn_str, alpn_len); mux_proto = ist2(alpn_str, alpn_len);
@ -1138,12 +1136,10 @@ static inline int conn_install_mux_be(struct connection *conn, void *ctx, struct
int alpn_len = 0; int alpn_len = 0;
int mode; int mode;
if (prx->mode == PR_MODE_TCP) if (prx->mode == PR_MODE_HTTP)
mode = PROTO_MODE_TCP; mode = ((prx->options2 & PR_O2_USE_HTX) ? PROTO_MODE_HTX : PROTO_MODE_HTTP);
else if (prx->options2 & PR_O2_USE_HTX)
mode = PROTO_MODE_HTX;
else else
mode = PROTO_MODE_HTTP; mode = PROTO_MODE_TCP;
conn_get_alpn(conn, &alpn_str, &alpn_len); conn_get_alpn(conn, &alpn_str, &alpn_len);
mux_proto = ist2(alpn_str, alpn_len); mux_proto = ist2(alpn_str, alpn_len);