nginx反向代理文件下载失败
通过nginx代理下载文件失败,文件只有几K可以下载,大于1M失败,原服务下载皆可成功。原因是nginx没有开起缓存,代理网络是立即响应的,默认没设置缓存,文件大了就会出现文件还没下载完成就反馈给客户端了,出现下载失败,因为拿到的不是一个完整的文件。需要设置nginx配置缓存,如下:# 文件不能下载 设置缓存proxy_buffering on;proxy_buffer_size 4k;proxy
通过nginx代理下载文件失败,文件只有几K可以下载,大于1M失败,原服务下载皆可成功。原因是nginx没有开起缓存,代理网络是立即响应的,默认没设置缓存,文件大了就会出现文件还没下载完成就反馈给客户端了,出现下载失败,因为拿到的不是一个完整的文件。应是读取的信息存入nginx临时文件,文件从原服务读取完后都存入nginx临时文件后将nginx临时文件内容反馈到客户端,这时客户端才能获取到完整的文件。设置nginx配置缓存如下:
# 文件不能下载 设置缓存
proxy_buffering on;
proxy_buffer_size 4k;
proxy_buffers 2 4k;
proxy_busy_buffers_size 4k;
proxy_temp_path /usr/local/nginx/proxy_temp 1 2;
proxy_max_temp_file_size 20M;
proxy_temp_file_write_size 8k;
# 文件不能下载结束
1. proxy_buffering on;
该参数设置是否开启proxy的buffer功能,参数的值为on或者off。
如果这个设置为off,那么proxy_buffers和proxy_busy_buffers_size这两个指令将会失效。
但是无论proxy_buffering是否开启,proxy_buffer_size都是生效的2. proxy_buffer_size 4k;
该参数用来设置一个特殊的buffer大小的。
从被代理服务器(C)上获取到的第一部分响应数据内容到代理服务器(B)上,通常是header,就存到了这个buffer中。
如果该参数设置太小,会出现502错误码,这是因为这部分buffer不够存储header信息。建议设置为4k。3. proxy_buffers 8 4k;
这个参数设置存储被代理服务器上的数据所占用的buffer的个数和每个buffer的大小。
所有buffer的大小为这两个数字的乘积。4. proxy_busy_buffer_size 16k;
在所有的buffer里,我们需要规定一部分buffer把自己存的数据传给A,这部分buffer就叫做busy_buffer。
proxy_busy_buffer_size参数用来设置处于busy状态的buffer有多大。对于buffer里的数据何时传输给A,我个人的理解是这样的:
1)如果完整数据大小小于busy_buffer大小,当数据传输完成后,马上传给A;
2)如果完整数据大小不少于busy_buffer大小,则装满busy_buffer后,马上传给A;5. proxy_temp_path
语法:proxy_temp_path path [level1 level2 level3]
定义proxy的临时文件存在目录以及目录的层级。例:proxy_temp_path /usr/local/nginx/proxy_temp 1 2;
其中/usr/local/nginx/proxy_temp为临时文件所在目录,1表示层级1的目录名为1个数字(0-9),2表示层级2目录名为2个数字(00-99)6. proxy_max_temp_file_size
设置临时文件的总大小,例如 proxy_max_temp_file_size 100M;7. proxy_temp_file_wirte_size
设置同时写入临时文件的数据量的总大小。通常设置为8k或者16k。
设置后重启nginx
重启后可能出现"/usr/local/nginx/proxy_temp/9/92/0000007929" failed (13: Permission denied) while reading upstream,client: 19.12.34.98, server: qcms.changanford.cn, request: "GET /sqcs/file/getAttachment._file?attachmentId=00000180-636c-6236-43e3-0bc495e79f13 HTTP/1.1", upstream 出现这个原因可能是临时文件权限问题,除了临时文件夹要有读写权限还要注意用户与组相匹配。
sudo chomd -R 765 proxy_temp sudo chown -R nobody:nobody /usr/local/nginx/proxy_temp
完整示例
server {
listen 80;
server_name 域名;
rewrite ^(.*)$ $host$1 permanent;
# 文件不能下载 设置缓存
proxy_buffering on;
proxy_buffer_size 4k;
proxy_buffers 2 4k;
proxy_busy_buffers_size 4k;
proxy_temp_path /usr/local/nginx/proxy_temp 1 2;
proxy_max_temp_file_size 20M;
proxy_temp_file_write_size 8k;
# 文件不能下载结束
#charset koi8-r;
#access_log logs/host.access.log main;
location ^~ /sqcs/ {
#root html;
proxy_pass http://ip/sqcs/;
index index.html index.htm;
proxy_cookie_path /sqcs /;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
更多推荐
所有评论(0)