Welcome! Log In Create A New Profile

Advanced

[nginx] HTTP/2: fixed buffer management with HTTP/2 auto-detection.

Sergey Kandaurov
October 21, 2023 10:56AM
details: https://hg.nginx.org/nginx/rev/ea1f29c2010c
branches:
changeset: 9179:ea1f29c2010c
user: Sergey Kandaurov <pluknet@nginx.com>
date: Sat Oct 21 18:48:24 2023 +0400
description:
HTTP/2: fixed buffer management with HTTP/2 auto-detection.

As part of normal HTTP/2 processing, incomplete frames are saved in the
control state using a fixed size memcpy of NGX_HTTP_V2_STATE_BUFFER_SIZE.
For this matter, two state buffers are reserved in the HTTP/2 recv buffer.

As part of HTTP/2 auto-detection on plain TCP connections, initial data
is first read into a buffer specified by the client_header_buffer_size
directive that doesn't have state reservation. Previously, this made it
possible to over-read the buffer as part of saving the state.

The fix is to read the available buffer size rather than a fixed size.
Although memcpy of a fixed size can produce a better optimized code,
handling of incomplete frames isn't a common execution path, so it was
sacrificed for the sake of simplicity of the fix.

diffstat:

src/http/v2/ngx_http_v2.c | 8 +++-----
src/http/v2/ngx_http_v2_module.c | 2 +-
2 files changed, 4 insertions(+), 6 deletions(-)

diffs (40 lines):

diff -r b74f891053c7 -r ea1f29c2010c src/http/v2/ngx_http_v2.c
--- a/src/http/v2/ngx_http_v2.c Fri Oct 20 18:05:07 2023 +0400
+++ b/src/http/v2/ngx_http_v2.c Sat Oct 21 18:48:24 2023 +0400
@@ -386,13 +386,11 @@ ngx_http_v2_read_handler(ngx_event_t *re
h2mcf = ngx_http_get_module_main_conf(h2c->http_connection->conf_ctx,
ngx_http_v2_module);

- available = h2mcf->recv_buffer_size - 2 * NGX_HTTP_V2_STATE_BUFFER_SIZE;
+ available = h2mcf->recv_buffer_size - NGX_HTTP_V2_STATE_BUFFER_SIZE;

do {
p = h2mcf->recv_buffer;
-
- ngx_memcpy(p, h2c->state.buffer, NGX_HTTP_V2_STATE_BUFFER_SIZE);
- end = p + h2c->state.buffer_used;
+ end = ngx_cpymem(p, h2c->state.buffer, h2c->state.buffer_used);

n = c->recv(c, end, available);

@@ -2592,7 +2590,7 @@ ngx_http_v2_state_save(ngx_http_v2_conne
return ngx_http_v2_connection_error(h2c, NGX_HTTP_V2_INTERNAL_ERROR);
}

- ngx_memcpy(h2c->state.buffer, pos, NGX_HTTP_V2_STATE_BUFFER_SIZE);
+ ngx_memcpy(h2c->state.buffer, pos, size);

h2c->state.buffer_used = size;
h2c->state.handler = handler;
diff -r b74f891053c7 -r ea1f29c2010c src/http/v2/ngx_http_v2_module.c
--- a/src/http/v2/ngx_http_v2_module.c Fri Oct 20 18:05:07 2023 +0400
+++ b/src/http/v2/ngx_http_v2_module.c Sat Oct 21 18:48:24 2023 +0400
@@ -388,7 +388,7 @@ ngx_http_v2_recv_buffer_size(ngx_conf_t
{
size_t *sp = data;

- if (*sp <= 2 * NGX_HTTP_V2_STATE_BUFFER_SIZE) {
+ if (*sp <= NGX_HTTP_V2_STATE_BUFFER_SIZE) {
return "value is too small";
}

_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
https://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[nginx] HTTP/2: fixed buffer management with HTTP/2 auto-detection.

Sergey Kandaurov 332 October 21, 2023 10:56AM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 127
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready