如果我们同时创建@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:在成功建立连接后,等待服务器响应数据的最长时间。
确保这些配置与您的实际环境和目标服务响应时间相适应,避免因为超时设置不合理导致请求失败或服务不可用的问题。