zl程序教程

您现在的位置是:首页 >  后端

当前栏目

【java】Spring Cloud --Feign Client超时时间配置以及单独给某接口设置超时时间方法

2023-09-14 09:14:21 时间


FeignClient面对服务级有三种超时时间配置

feign配置(最常用)

feign:
  sentinel:
    enabled: true
  client:
    config:
      default://全部服务配置
        connectTimeout: 5000
        readTimeout: 5000
        loggerLevel: FULL
      serversname://单独给某一服务配置 这里的serversname是服务名,使用的时候要用服务名替换掉这个
        connectTimeout: 5000
        readTimeout: 5000

ribbon[ˈrɪbən]配置

ribbon:
  ReadTimeout:毫秒时间 同feign一样的
  ConnectTimeout:毫秒时间 同feign一样的

feign配置是在ribbon配置的基础上做了扩展,可以支持服务级超时时间配置,所以,feign配置和ribbon配置的效果应该是一样的。

SpringCloud对这两种配置的优先级顺序如下:
Feign局部配置 > Feign全局配置 > Ribbon局部配置 > Ribbon全局配置

hystrix配置

hystrix:
  command:
    default://default默认为所有接口,可以配置指定接口
      execution:
        isolation:
          thread:
            timeoutInMilliseconds:毫秒时间

单独给某接口设置超时时间

在feign-core的jar包里有个Request类

import feign.Request;

在feign接口里加入这个参数就可以单独为接口单独设置超时时间了

@PostMapping("test/")
ResponseVO<?> test(Request.Options options, @RequestBody TestRequestEntity entity);

调用的时候new 一下Options对象

 ResponseVO<?> resp = client.test(
        new Request.Options(70, TimeUnit.SECONDS, 70, TimeUnit.SECONDS, true),
        entity);

这样就可以为那些单独需要很长时间才能完成的接口(比如大文件上传等)设置超时时间了。