OpenFeign配置说明

如果我们同时创建@Configuration 配置类和配置属性,将优先使用配置属性。它将覆盖@Configuration值。但是如果您想将优先级更改为@Configuration,可以将feign.client.default-to-properties更改为false。

OpenFeign在Spring Cloud中整合了Ribbon或LoadBalancerClient(对于较新的Spring Cloud版本),允许你设置HTTP客户端的超时时间。

当Hystrix启用时,其超时配置默认为1000毫秒。因此,它可能发生在我们之前配置的客户端超时之前。增加超时时间可以防止这种情况发生。

以下是如何在配置文件中为OpenFeign设置连接超时和读取超时:
1. 对于所有Feign客户端设置全局超时:

# Spring Cloud应用的application.yml或application.properties文件中
feign:
  client:
    config:
      default: # 这里的"default"是默认配置,也可以替换为特定的服务名
        connectTimeout: 5000 # 连接超时时间,单位毫秒
        readTimeout: 5000 # 读取超时时间,单位毫秒
        errorDecoder: # 自定义错误解码器类名
        retryer: # 自定义重试策略类名
        decoder: # 自定义响应解码器类名
        encoder: # 自定义请求编码器类名
        requestInterceptors: # 请求拦截器列表
        loggerLevel: # 日志级别,可选值有:NONE, BASIC, HEADERS, FULL
        decode404: false # 是否将HTTP 404状态码视为成功并进行解码,默认false

  hystrix:
    enabled: true  #是否启用hystrix,默认false
  okhttp:
    enabled: false # 是否启用okhttp,默认false

hystrix:
  command:
    default:
      execution:
        timeout:
          enabled: true
        isolation:
          thread:
            timeoutInMilliseconds: 60000

2. 对于特定Feign客户端设置超时:

feign:
  client:
    config:
      my-service: # 替换为你的Feign客户端接口上的`@FeignClient(name="my-service")`指定的名字
        connectTimeout: 3000 # 特定服务的连接超时时间
        readTimeout: 10000 # 特定服务的读取超时时间

解释:
connectTimeout:指的是建立到远程服务器的TCP连接所花费的最大时间。
readTimeout:在成功建立连接后,等待服务器响应数据的最长时间。
确保这些配置与您的实际环境和目标服务响应时间相适应,避免因为超时设置不合理导致请求失败或服务不可用的问题。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值