Merge remote-tracking branch 'origin/main'
# Conflicts: # Makefile # debian/changelog # tests/01-module/01-e2e.robot
This commit is contained in:
@@ -2128,6 +2128,17 @@ ngx_http_ipng_stats_log_handler(ngx_http_request_t *r)
|
||||
bin_sz = r->request_length > 0 ? (uint64_t) r->request_length : 0;
|
||||
bout_sz = (uint64_t) r->connection->sent;
|
||||
|
||||
/* When nginx rejects a request before any handler reads the body
|
||||
* (rate-limit 403, auth_request denial, 413 on fixed Content-Length,
|
||||
* early `return 4xx;` on POST, ...), the body goes through
|
||||
* ngx_http_discard_request_body / HTTP/2 skip_data, which do NOT
|
||||
* update r->request_length. If the client advertised a
|
||||
* Content-Length, fall back to that as a tight upper bound on the
|
||||
* bytes we actually received. See docs/nginx-issues.md. */
|
||||
if (r->discard_body && r->headers_in.content_length_n > 0) {
|
||||
bin_sz += (uint64_t) r->headers_in.content_length_n;
|
||||
}
|
||||
|
||||
slot->requests += 1;
|
||||
slot->bytes_in += bin_sz;
|
||||
slot->bytes_out += bout_sz;
|
||||
|
||||
Reference in New Issue
Block a user