领课教育开源系统-Spring Cloud Zuul 如何上传大文件

领课在线教育系统采用Spring Cloud Zuul作为网关,大文件上传导致堆内存问题,可能出现OOM异常。官方推荐通过代理路径上传,或在nginx中直接转发到后端微服务以避免网关处理大文件。解决方案包括调整路径以绕过Spring DispatcherServlet,或使用nginx进行转发,并需注意超时和文件大小限制配置。
摘要由CSDN通过智能技术生成

目前领课在线教育系统使用Spring Cloud Zuul作为网关组件,上传文件会先经过网关(gateway),然后再交给后端微服务(course)。这种情况下,网关(zuul)的堆内存会随着文件的传入而变化,小文件影响不大,但是大文件会使得堆内存急速上升,当网关的内存设置小于上传文件的大小时,就会出现OOM异常。在开发期间,上传的文件一般不大,很难发现。

官方文档介绍:

如果你使用@EnableZuulProxy,你可以使用代理路径来上传文件,只要文件很小,它就可以工作。对于大文件,有另一种路径,可以绕过Spring DispatcherServlet(以避免多部分处理)在“/zuul/”中。换句话说,如果你有zuul.route.customers=/customers/,然后您可以将大文件发布到/zuul/customers/。

所以在领课教育系统中,看到上传的文件都会默认加上:/zuul作为前缀

特别注意

虽然这样是绕过Spring DispatcherServlet,但是超时时间一样要设置

hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=240000
ribbon.ConnectTimeout=10000
ribbon.ReadTimeout=60000
特别说明:ribbon.ConnectTimeout和ribbon.ReadTimeout里面的参数是大写的,当时自己以为是官方的错误,擅自修改为小写&
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值