I am getting this error from Nginx, but can\'t seem to figure it out! I am using codeigniter and am using the database for sessions. So I\'m wondering how the header can eve
I had the same problem because I use a nginx + fcgiwrap configuration:
location ~ ^.*\.cgi$ {
fastcgi_pass unix:/var/run/fcgiwrap.sock;
fastcgi_index index.cgi;
fastcgi_param SCRIPT_FILENAME /opt/nginx/bugzilla/$fastcgi_script_name;
include /etc/nginx/fastcgi_params;
# attachments can be huge
client_max_body_size 0;
client_body_in_file_only clean;
# this is where requests body are saved
client_body_temp_path /opt/nginx/bugzilla/data/request_body 1 2;
}
and the client was doing a request with a URL that was about 6000 characters (a bugzilla request).
location ~ ^.*\.cgi$ {
error_log /var/log/nginx/bugzilla.log debug;
# ...
}
This is what I got in the logs:
2015/03/18 10:24:40 [debug] 4625#0: *2 upstream split a header line in FastCGI records
2015/03/18 10:24:40 [error] 4625#0: *2 upstream sent too big header while reading response header from upstream, client: 10....
Yes you can!
I was reading How to set the allowed url length for a nginx request (error code: 414, uri too large) before because I thought "hey the URL's too long" but I was getting 502's rather than 414's.
large_client_header_buffers
Try #1:
# this goes in http or server block... so outside the location block
large_client_header_buffers 4 8k;
This fails, my URL is 6000 characters < 8k. Try #2:
large_client_header_buffers 4 4k;
Now I don't see a 502 Bad Gateway anymore and instead I see a 414 Request-URI Too Large
Did some research and found somewhere on the internet:
This was sufficient for me:
location ~ ^.*\.cgi$ {
# holds request bigger than 4k but < 8k
fastcgi_buffer_size 8k;
# getconf PAGESIZE is 4k for me...
fastcgi_buffers 16 4k;
# ...
}