记nginx反向代理情况下上传大文件报413 Request Entity Too Large(请求实体过大)解决方法

发布于:2023-07-04 ⋅ 阅读:(249) ⋅ 点赞:(0)

这里写自定义目录标题

问题描述

系统服务端采用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 {
       ……
    }
 }
本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到