Nginx在5 MB数据后截断响应

时间:2018-11-08 15:50:59

标签: nginx nginx-reverse-proxy

使用Nginx -v 1.10.3(Ubuntu),我对虚拟主机具有以下配置:

server {
  listen 443 ssl;
  listen [::]:443 ssl;

  include snippets/ssl.conf;

  server_name  myserver.example.com;

  proxy_buffering off;
  proxy_store off;

  location / {
    include proxy_params;
    client_max_body_size 100m;
    proxy_pass http://127.0.0.1:3033;
    proxy_buffering off;
  }

}

代理的应用程序是Rails应用程序。我最多可以上传100MB的文件。

include snippets/ssl.conf

仅包含证书。

include proxy_params;

包含以下指令:

proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;

当我通过SSH通过隧道3033连接到后端时,我可以下载文件,它们是相同的。

通过代理连接时,无论文件类型或原始大小如何,文件总是在5242880字节后被截断-即5MB。

截断是一致的。磁盘上有足够的可用空间,还有足够的可用索引节点。 Nginx日志中没有错误消息。

当tryint加载31MB文件时(进行机芯安装...),访问日志显示如下:

AAA.BBB.CCC.DDD - - [08/Nov/2018:16:36:59 +0100] "GET /rails/active_storage/disk/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaEpJaDFsVlVkdlVFaFFha1E1V2tKUk5HbG9RMVU0Vm1JNGJVY0dPZ1pGVkE9PSIsImV4cCI6IjIwMTgtMTEtMDhUMTU6NDE6NTkuMDMyWiIsInB1ciI6ImJsb2Jfa2V5In19--9ba3dd25c32c16ce10ef884b80f9f6d3705717f2/calibre-3.33.1.dmg?content_type=application%2Fx-bzip&disposition=attachment%3B+filename%3D%22calibre-3.33.1.dmg%22%3B+filename%2A%3DUTF-8%27%27calibre-3.33.1.dmg HTTP/1.1" 200 5253135 "https://myserver.example.com/supplies/2" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"

因此文件大小显示已被截断。

我已经完成作业,浏览了nginx文档并进行了搜索,但是所有其他用户报告了错误日志中的错误,随机截断或仅截断某些文件类型。

任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:2)

我刚从@amiuhle得到了一个对my case有用的答案:

  

使用proxy_http_version 1.1;

     

默认情况下,nginx使用HTTP 1.0进行代理,但不支持   分块传输编码。

     

http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_http_version