问题描述
系统服务端采用nginx配置反向代理,post请求上传文件时如文件过大(1mb文件已经报文件过大),返回状态码413的 Request Entity Too Large(请求实体过大)错误。
站点nginx配置如下:
如下图:
问题分析
刚开始怀疑WAF是否对请求进行拦截,查看waf的拦截记录未发现有被拦截的痕迹,马上就想到了nginx的默认配置设置,默认是1mb,这次忘记对他进行设置。所以上传超过1mb的文件请求就会被阻断,不会到系统的网关服务。
解决办法
在nginx的配置文件增加
client_max_body_size 0; 参数,表示大小不限(因为我们网关已经配置了上传文件大小能力,而这个ngxin反代主要是为了前端和服务端在同一个域下,方便部署省得每次需要修改网关的跨域策略,导致服务需要重启),所以我这里直接在http节点下配置为不限制。大家请根据自己的需求进行修改。建议设置nginx反代缓冲区等参数进行优化,也可以在各server中独立配置限制大小。
配置文件如下:
user nginx;
worker_processes auto;
error_log /错误日志保存地址/error.log;
pid /run/nginx.pid;
include /nginx安装目录/modules/*.conf;
events {
worker_connections 1024;
}
http {
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /日志保存目录/日志文件名称.log main;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
client_max_body_size 0; // 设置请求实体大小不限制
server_tokens off;
include /ngxin文件安装目录/mime.types;
default_type application/octet-stream;
server {
……
}
}