使用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文档并进行了搜索,但是所有其他用户报告了错误日志中的错误,随机截断或仅截断某些文件类型。
任何帮助将不胜感激。
答案 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