Sping-Cloud使用BUG-01-网关超时

使用BUG-01-网关超时

BUG场景

是酱紫的,使用的时候,请求过网关到微服务,2秒以内的请求没有问题,超过的就报超时,【zuul就熔断了】

BUG报错

zuul 报错:timed-out and no fallback available,failed and no fallback available

com.netflix.zuul.exception.ZuulException: Forwarding error
        at org.springframework.cloud.netflix.zuul.filters.route.RibbonRoutingFilter.forward(RibbonRoutingFilter.java:143)
        at org.springframework.cloud.netflix.zuul.filters.route.RibbonRoutingFilter.run(RibbonRoutingFilter.java:107)
        at com.netflix.zuul.ZuulFilter.runFilter(ZuulFilter.java:112)

java.net.SocketTimeoutException: Read timed out
        at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.read(SocketInputStream.java:152)
        at java.net.SocketInputStream.read(SocketInputStream.java:122)
        at org.apache.http.impl.io.AbstractSessionInputBuffer.fillBuffer(AbstractSessionInputBuffer.java:166)
        at org.apache.http.impl.io.SocketInputBuffer.fillBuffer(SocketInputBuffer.java:90)

解决方案1

timed-out and no fallback available这个错误基本是出现在Hystrix熔断器,熔断器的作用是判断该服务能不能通,如果通了就不管了,调用在指定时间内超时时,就会通过熔断器进行错误返回。

  • 把超时时间设长

    hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000  # 默认值为1000(1秒)
  • 把超时发生异常属性关闭

    hystrix.command.default.execution.timeout.enabled: false
  • 禁用feign的hystrix

    feign.hystrix.enabled: false

上面设置其中一个即可。[只是关闭熔断,但是超时的这个错误还是存在的]
上面设置只是针对熔断器的错误关闭,并不能解决根本问题,比如Feign客户端调用远程服务时,默认为8秒超时时间,如果在规定时间内没有返回,同样会跳转到熔断器进行处理。即使关闭了熔断器的错误,但是总的错误处理还会是有这个问题出现。

解决方案2

解决超时问题的根本,就要从请求超时时间入手,因为有些服务可能存在调用时间长的问题,所以直接配置:

ribbon.ReadTimeout=60000
ribbon.ConnectTimeout=60000
这些才是真正解决请求超时的问题,如果不设置这个,被调用接口很慢时,会出现Read Timeout on Request。
ribbon.maxAutoRetries=0  :而针对调用失败重试的次数也可以设置

其他资料

  • 配置说明

    hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000  # 默认值为1000(1秒)
    ribbon:
        ConnectTimeout: 250             :请求连接的超时时间
        ReadTimeout: 1000               :请求处理的超时时间
        OkToRetryOnAllOperations: true  :对所有操作请求都进行重试
        MaxAutoRetriesNextServer: 2     :切换实例的重试次数
        MaxAutoRetries: 2               :对当前实例的重试次数
    # 断路器的超时时间需要大于ribbon的超时时间,不然不会触发重试

这里面ribbon和hystrix是同时生效的,哪个值小哪个生效,另一个就看不到效果了。

  • 官方说明:官方文档

    如果您想配置套接字超时以及通过Zuul代理请求读取超时,则根据您的配置,您有两个选项:
    如果Zuul使用服务发现,则需要使用ribbon.ReadTimeout和ribbon.SocketTimeout功能区属性配置这些超时 。
    如果您通过指定URL来配置Zuul路由,则需要使用 zuul.host.connect-timeout-millis和zuul.host.socket-timeout-millis。

具体使用调试

自己使用的时候,使用的是如下配置

hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 5000 

ribbon:  
  ReadTimeout: 60000  
  ConnectTimeout: 60000  
  maxAutoRetries: 0         

zuul:
  host:
    connect-timeout-millis: 60000
    socket-timeout-millis: 60000

2018-06-14 小杭

相关文章
相关标签/搜索