解决nginx文件上传限制&超时无响应

一、背景

笔者最近开发前后端分离项目遇到一些问题,后端服务是基于80/443端口反向代理的,所以请求会经过nginx网关,然后将请求代理到后端服务,这是开发环境。

二、问题

  • 文件上传大小有限制
  • 上传传时间过长无响应

二、解决方案

conf 复制代码
http {
    ...

    # 性能优化
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;

    # 客户端请求配置
    client_max_body_size 1000M;   # 解决文件上传大小限制
    client_body_buffer_size 2M; 
    client_header_buffer_size 256k;
    large_client_header_buffers 4 256k;

    # 超时设置            
    client_body_timeout 600s;
    client_header_timeout 600s;
    keepalive_timeout 120s;
    keepalive_requests 1000;

    # 反向代理配置
    proxy_connect_timeout 600s;
    proxy_send_timeout 600s;
    proxy_read_timeout 600s;
}

经过以上客户端请求配置和超时配置后按理说就解决了上面两个问题了,可是当我再进行测试的时候,接口依旧1分钟请求超时。

最后我想了一圈也没想到竟然是axios请求超时配置是60000ms,也就是1分钟,此时此刻豁然开朗了。

js 复制代码
const service = axios.create({
	baseURL: '/api', // api base_url
	timeout: 300000 // 请求超时时间, 配置为5分钟
})

再进行测试

🆗,也是上传成功了,没想到用时2.6分钟。

四、总结

配置nginx文件限制不仅仅在nginx中配置,后端服务也要配置,因为有好几层网关,例如SpringBoot的配置:

properties 复制代码
# multipart configuration
spring.servlet.multipart.max-request-size=100MB
spring.servlet.multipart.max-file-size=100MB

还有就是请求超时配置,例如axios的请求超时时间:

js 复制代码
const service = axios.create({
	baseURL: '/api', // api base_url
	timeout: 300000 // 请求超时时间, 配置为5分钟
})

最后还有nginx配置:

conf 复制代码
http {
    ...

    # 性能优化
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;

    # 客户端请求配置
    client_max_body_size 100M;   # 解决文件上传大小限制
    client_body_buffer_size 2M; 
    client_header_buffer_size 256k;
    large_client_header_buffers 4 256k;

    # 超时设置            
    client_body_timeout 600s;
    client_header_timeout 600s;
    keepalive_timeout 120s;
    keepalive_requests 1000;

    # 反向代理配置
    proxy_connect_timeout 600s;
    proxy_send_timeout 600s;
    proxy_read_timeout 600s;
}

这三板斧下来就能够解决大部分文件上传问题了。

相关推荐
qq_2975746714 小时前
【实战教程】SpringBoot 实现多文件批量下载并打包为 ZIP 压缩包
java·spring boot·后端
计算机程序设计小李同学1 天前
基于 Spring Boot + Vue 的龙虾专营店管理系统的设计与实现
java·spring boot·后端·spring·vue
Charlie_lll1 天前
力扣解题-[3379]转换数组
数据结构·后端·算法·leetcode
VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue云租车平台系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
汤姆yu1 天前
2026基于springboot的在线招聘系统
java·spring boot·后端
计算机学姐1 天前
基于SpringBoot的校园社团管理系统
java·vue.js·spring boot·后端·spring·信息可视化·推荐算法
hssfscv1 天前
Javaweb学习笔记——后端实战8 springboot原理
笔记·后端·学习
咚为1 天前
Rust tokio:Task ≠ Thread:Tokio 调度模型中的“假并发”与真实代价
开发语言·后端·rust
Anastasiozzzz1 天前
对抗大文件上传---分片加多重Hash判重
服务器·后端·算法·哈希算法
Vivienne_ChenW1 天前
DDD领域模型在项目中的实战
java·开发语言·后端·设计模式