解决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;
}

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

相关推荐
eLIN TECE13 分钟前
springboot和springframework版本依赖关系
java·spring boot·后端
老神在在00130 分钟前
Spring Bean 的六种作用域详解
java·后端·spring
星辰_mya2 小时前
OSI 七层模型之“跨国诈骗集团”深度讲解
运维·服务器·后端·面试·架构师
IT_陈寒2 小时前
SpringBoot自动配置这破玩意儿又坑我一次
前端·人工智能·后端
码事漫谈3 小时前
Cursor+Graphify实属强强联合了
后端
用户298698530143 小时前
不用无头浏览器,Java 如何将 HTML 转成图片?
java·后端
我叫黑大帅3 小时前
其实跨域问题是后端来解决的? CORS
后端·面试·go
掘金一周3 小时前
掘友们,一人说一个你买过夯到爆的东西 | 沸点周刊 4.23
前端·人工智能·后端
Developer_Niuge3 小时前
告别翻不动的 1000+ 书签:开源 Chrome / Edge 浏览器书签管理插件 Smart Bookmark 0.2 发布
前端·后端
ElevenPlus4 小时前
【 AI智能体时代:一名Javaer的技术随想录】MCP服务部署架构
后端