Nginx 413 Request Entity Too Large,文件上传过程中的问题

在上传时nginx返回了413错误,查看log文件,显示的错误信息是:”413 Request Entity Too Large”。
以下介绍处理办法。

1 处理方式如下

1.打开nginx配置文件 nginx.conf, 路径一般是:/etc/nginx/nginx.conf,或者/usr/local/nginx。
2.在http{}段中加入 client_max_body_size 20m; 20m为允许最大上传的大小。(设置超过20m可能无效)
3.同时,还需要设置client_body_buffer_size的值,要求client_body_buffer_size<=client_max_body_size 。可以直接设置两者相等大小。
4.保存后重启nginx,问题解决。nginx操作可以参考 nginx操作
设置值如下:

    client_max_body_size 20M;
    client_body_buffer_size 20M;

效果图如下:
在这里插入图片描述

2 相关原理记录如下:

1)client_max_body_size
client_max_body_size 默认 1M,表示 客户端请求服务器最大允许大小,在“Content-Length”请求头中指定。如果请求的正文数据大于client_max_body_size,HTTP协议会报错 413 Request Entity Too Large。就是说如果请求的正文大于client_max_body_size,一定是失败的。如果需要上传大文件,一定要修改该值。
2)client_body_buffer_size
Nginx分配给请求数据的Buffer大小,如果请求的数据小于client_body_buffer_size直接将数据先在内存中存储。如果请求的值大于client_body_buffer_size小于client_max_body_size,就会将数据先存储到临时文件中,在哪个临时文件中呢?client_body_temp 指定的路径中,默认该路径值是/tmp/.
所以配置的client_body_temp地址,一定让执行的Nginx的用户组有读写权限。否则,当传输的数据大于client_body_buffer_size,写进临时文件失败会报错。

总结
传输的数据大于client_max_body_size,一定是传不成功的。小于client_body_buffer_size直接在内存中高效存储。如果大于client_body_buffer_size小于client_max_body_size会存储临时文件,临时文件一定要有权限。
如果追求效率,就设置 client_max_body_size client_body_buffer_size相同的值,这样就不会存储临时文件,直接存储在内存了。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值