【问题标题】:Spring cloud gateway gives connection closed prematurelySpring Cloud Gateway 使连接过早关闭
【发布时间】:2019-05-10 00:45:00
【问题描述】:

我在我的微服务设置中使用 spring cloud gateway 作为 API 网关,并使用 consul 作为服务发现。

在某些情况下,当某些微服务的 API 需要超过 2 分钟时,网关会抛出以下错误:

java.io.IOException: Connection closed prematurely
at reactor.ipc.netty.http.client.HttpClientOperations.onInboundClose(HttpClientOperations.java:269)
at reactor.ipc.netty.channel.ChannelOperationsHandler.channelInactive(ChannelOperationsHandler.java:113)
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:245)
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:231)
at io.netty.channel.AbstractChannelHandlerContext.fireChannelInactive(AbstractChannelHandlerContext.java:224)
at io.netty.channel.CombinedChannelDuplexHandler$DelegatingChannelHandlerContext.fireChannelInactive(CombinedChannelDuplexHandler.java:420)
at io.netty.handler.codec.ByteToMessageDecoder.channelInputClosed(ByteToMessageDecoder.java:377)
at io.netty.handler.codec.ByteToMessageDecoder.channelInactive(ByteToMessageDecoder.java:342)
at io.netty.handler.codec.http.HttpClientCodec$Decoder.channelInactive(HttpClientCodec.java:282)
at io.netty.channel.CombinedChannelDuplexHandler.channelInactive(CombinedChannelDuplexHandler.java:223)
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:245)
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:231)
at io.netty.channel.AbstractChannelHandlerContext.fireChannelInactive(AbstractChannelHandlerContext.java:224)
at io.netty.channel.DefaultChannelPipeline$HeadContext.channelInactive(DefaultChannelPipeline.java:1429)
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:245)
at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:231)
at io.netty.channel.DefaultChannelPipeline.fireChannelInactive(DefaultChannelPipeline.java:947)
at io.netty.channel.AbstractChannel$AbstractUnsafe$8.run(AbstractChannel.java:822)
at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:163)
at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:404)
at io.netty.channel.epoll.EpollEventLoop.run(EpollEventLoop.java:313)
at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:884)
at java.lang.Thread.run(Thread.java:745)

我多次尝试相同的 API,2 分钟后出现此错误。

是否有任何属性设置。 版本和依赖细节:

compile('org.springframework.cloud:spring-cloud-starter-consul-discovery')
compile('org.springframework.cloud:spring-cloud-starter-gateway')
compile('org.springframework.cloud:spring-cloud-starter-openfeign')


springBootVersion=2.0.3.RELEASE
springDMPVersion=1.0.4.RELEASE
springPlatformBomVersion=Cairo-SR2

功能区设置:

ribbon:
  ConnectTimeout: 3000
  ReadTimeout: 3000

【问题讨论】:

  • 您能否提供包含这些更改的示例 repo?我想试试。谢谢。
  • 您是否使用 Spring RestTemplate 发送请求?
  • 不确定,网关负责将请求转发给应用程序。不了解底层实现
  • 是的,但我看到您使用的是功能区,它是客户端负载平衡器。所以我假设您还控制拨打电话的客户端?那是什么客户?

标签: java spring-boot spring-cloud netflix-ribbon spring-cloud-gateway


【解决方案1】:

我也遇到了类似的问题。 spring gateway调用其他服务时,上传文件时报同样的错误。我尝试将以下配置添加到被调用服务的 yaml 文件中。这就是解决方案。你也可以试试

弹簧: 小服务程序: 多部分: 最大文件大小:50MB 最大请求大小:50MB

【讨论】:

    【解决方案2】:

    下游服务出现问题。

    在我的应用程序中,有 nodejs 应用程序在 spring 云网关后面运行,默认超时为 2 分钟。

    参考:https://github.com/expressjs/express/issues/3330

    在我的情况下,2 分钟后,nodejs 应用程序超时,这就是我在网关中收到错误的原因。

    我通过更改节点应用程序中的超时值来解决它

    【讨论】:

      猜你喜欢
      • 2022-11-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-11-09
      • 1970-01-01
      • 2014-11-09
      • 1970-01-01
      • 2019-03-25
      相关资源
      最近更新 更多