Upstream too big - nginx + codeigniter

前端 未结 6 1727
深忆病人
深忆病人 2020-11-30 20:08

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

6条回答
  •  无人及你
    2020-11-30 20:43

    using nginx + fcgiwrap + request too long

    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).

    debugging...

    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....
    

    can I have "414 request-uri too large" instead of "502 bad gateway"?

    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

    "upstream split a header line in FastCGI records"

    Did some research and found somewhere on the internet:

    • http://forum.nginx.org/read.php?2,4704,4704
    • https://www.ruby-forum.com/topic/4422529
    • http://mailman.nginx.org/pipermail/nginx/2009-August/014709.html
    • http://mailman.nginx.org/pipermail/nginx/2009-August/014716.html

    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;
        # ...
    }
    

提交回复
热议问题