怀疑nginx client_max_body_size没有处理408错误

时间:2017-07-19 18:49:29

标签: reactjs nginx hapijs

我有一个Hapi.js,Node后端配置为从我的React前端接受高达20M的文件,适用于在没有NGINX的情况下上传大型文件。当我在生产中包含NGINX时,我在浏览器中收到408错误,但在NGINX错误日志中却没有。

由于只能成功上传小于1MB的文件,我认为问题是client_max_body大小为默认的1MB。但无论我在哪里增加它(即:http,服务器,位置),它都没有效果。这是我的整个NGINX配置。

我想知道是否有其他人经历过这个,或者知道为什么408错误没有出现在日志中?我真的很感激一些帮助。

events {
        worker_connections 1024;
        # multi_accept on;
}

http {

        sendfile                          on;
        tcp_nopush                        on;
        tcp_nodelay                       on;
        keepalive_timeout                 65;
        types_hash_max_size               2048;

        client_header_timeout             3m;
        client_body_timeout               3m;
        send_timeout                      3m;
        client_header_buffer_size         1k;
        large_client_header_buffers       4 4k;

        client_max_body_size              20M;

        include /etc/nginx/mime.types;
        default_type application/octet-stream;


        ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
        ssl_prefer_server_ciphers on;

        access_log /var/log/nginx/access.log;
        error_log /var/log/nginx/error.log;

        gzip on;
        gzip_disable "msie6";

        server {
                listen 80 default_server;
                listen [::]:80 default_server;

                client_max_body_size 20M;

                server_name _;
                root /var/www/front;
                index index.html index.htm;

                location ~* \.(?:manifest|appcache|html?|xml|json)$ {
                        add_header Access-Control-Allow-Origin *;
                        expires -1;
                        client_max_body_size 20M;
                }

                location ~* \.(?:css|js)$ {
                        add_header Access-Control-Allow-Origin *;
                        try_files $uri =404;
                        expires 1y;
                        access_log off;
                        add_header Cache-Control "public";
                        client_max_body_size 20M;
                }

                location ~ ^.+\..+$ {
                        add_header Access-Control-Allow-Origin *;
                        try_files $uri =404;
                        client_max_body_size 20M;
                }

                location / {
                        add_header Access-Control-Allow-Origin *;
                        try_files $uri $uri/ /index.html;
                        client_max_body_size 20M;
                }


                location /api {
                        proxy_set_header Access-Control-Allow-Origin *;
                        proxy_pass http://my-ip-address:3000;
                        proxy_http_version 1.1;
                        proxy_set_header Upgrade $http_upgrade;
                        proxy_set_header Connection 'upgrade';
                        proxy_set_header Host $host;
                        proxy_cache_bypass $http_upgrade;

                        client_max_body_size 20M;

                        client_body_buffer_size 128k;
                        client_body_temp_path /var/nginx/client_body_temp;
                        proxy_connect_timeout 70;
                        proxy_send_timeout 90;
                        proxy_read_timeout 90;
                        proxy_buffer_size 4k;
                        proxy_buffers 4 32k;
                        proxy_busy_buffers_size 64k;
                        proxy_temp_file_write_size 64k;
                        proxy_temp_path /var/nginx/proxy_temp;
                }


        }
}

1 个答案:

答案 0 :(得分:0)

当我遇到身体尺寸问题时,nginx会给我413错误,我可以用client_max_body_size修复它,所以这可能是别的。

根据nginx文档,由于client_body_timeoutclient_header_timeout中的设置,可能会返回408错误,但您的错误已经设置为3m,因此我不知道是否存在错误也适用。也许尝试将这些值设置为疯狂,以确定它是否有帮助?