Opened 5 months ago

Last modified 5 months ago

#2668 new defect

client_body_buffer_size - Body Larger Than Buffer Size Is Omitted

Reported by: shalhevetm@… Owned by:
Priority: major Milestone:
Component: other Version: 1.21.x
Keywords: client_body_buffer_size Cc:
uname -a: Linux podname 5.15.133+ #1 SMP Sat Dec 30 13:01:38 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux
nginx -V: openresty/1.21.4.3

Description (last modified by shalhevetm@…)

I set client_body_buffer_size to 4MB and client_max_body_size to 150MB.
When I send a request with a 6 MB body (6MB sized argument), in access_by_lua_block, the body appears as empty.

access_by_lua_block {

ngx.req.read_body()
local body_data = ngx.req.get_body_data()

if body_data then

ngx.log(ngx.ERR, "Request body: ", body_data)

else

ngx.log(ngx.ERR, "No request body found")

end

}

I see the log "No request body found", even though the body was clearly not empty.

client_body_in_single_buffer is default (wasn't set).

When I increased client_body_buffer_size to 10MB, I had no issues with the 6MB body.

Why is that so? Why does the buffer size cause the body to appear as empty?

Change History (1)

comment:1 by shalhevetm@…, 5 months ago

Description: modified (diff)
Note: See TracTickets for help on using tickets.