nginx上传文件大小
2016-05-23 18:23
393 查看
采用nginx作反向代理,出现了一个诡异的问题,小文件可以提交,大文件会报500内部错误。这个是什么原因导致的呢?
查wiki可知,上传文件大小相关的有三个配置
client_body_buffer_size 配置请求体缓存区大小, 不配的话,
client_body_temp_path 设置临时文件存放路径。只有当上传的请求体超出缓存区大小时,才会写到临时文件中
client_max_body_size 设置上传文件的最大值
所以查出来,问题出现的原因是
1.文件大小超过了client_body_buffer_size
2.client_body_temp_path的临时文件路径居然没有写权限
以上两个原因导致了返回500错误。
如果上传文件大小超过client_max_body_size时,会报413 entity too large的错误。
原因知道了,修正就简单了。
1.client_body_buffer_size 尽量设置的大点,这是基于速度的考虑,如果因为设置的过小,导致上传的文件老要写磁盘,那速度就太慢了。
2.client_body_temp_path 路径要有可写权限,这个是明显的错误了。改正了就好
3.client_max_body_size 设置上传文件的最大值,这个是基于安全的考虑,我们认为正常用户不会或者基本不会上传太大的文件。
可以设置为client_max_body_size 100m; 或者按照自己的业务来设置这个值。
查wiki可知,上传文件大小相关的有三个配置
client_body_buffer_size 配置请求体缓存区大小, 不配的话,
client_body_temp_path 设置临时文件存放路径。只有当上传的请求体超出缓存区大小时,才会写到临时文件中
client_max_body_size 设置上传文件的最大值
所以查出来,问题出现的原因是
1.文件大小超过了client_body_buffer_size
2.client_body_temp_path的临时文件路径居然没有写权限
以上两个原因导致了返回500错误。
如果上传文件大小超过client_max_body_size时,会报413 entity too large的错误。
原因知道了,修正就简单了。
1.client_body_buffer_size 尽量设置的大点,这是基于速度的考虑,如果因为设置的过小,导致上传的文件老要写磁盘,那速度就太慢了。
2.client_body_temp_path 路径要有可写权限,这个是明显的错误了。改正了就好
3.client_max_body_size 设置上传文件的最大值,这个是基于安全的考虑,我们认为正常用户不会或者基本不会上传太大的文件。
可以设置为client_max_body_size 100m; 或者按照自己的业务来设置这个值。
相关文章推荐
- nginx配置优先级
- Redstone 云观象台 服务器部署 - Nginx配置文件
- nginx查看目标文件夹内容
- Nginx安装与配置文件解析
- 转: 基于nginx的hls直播系统
- linux安装nginx
- nginx rewrite proxy_pass location 的理解
- 2016 -Nginx的负载均衡 - 一致性哈希 (Consistent Hash)
- 转:nginx 从入门到精通的博文
- 使用Nginx负载均衡
- Nginx防攻击杀手锏
- Ubuntu FastDFSv5.05+Nginx1.9.15 环境搭建
- nginx的基本配置和虚拟主机的配置
- Ansible安装配置Nginx
- nginx禁止未绑定域名访问 并且强行断开连接
- nginx配置静态资源地址
- 转:Nginx RTMP 功能研究
- Ubuntu下Nginx简单使用
- nginx整理
- CenOS Linux安装nginx