https://blog.csdn.net/2401_82884096/article/details/138620659
OpenFeign 允许配置超时
和重试机制
,以便在调用远程服务时能够更好地处理网络异常和服务不可用
的情况。
通过配置连接超时和读取超时,可以控制 OpenFeign 在发起请求后等待响应的时间。如果在指定的超时时间内未收到响应,OpenFeign 将抛出超时异常。
OpenFeign 可以配置重试策略,以处理由于网络问题或服务不可用导致的请求失败情况。通过配置重试次数
和重试间隔
,可以使得 OpenFeign 在请求失败时重试一定次数,直到请求成功或达到最大重试次数。
详细代码如下:
@FeignClient(name = "service-b", configuration = MyFeignClientConfiguration.class)
public interface ServiceBClient {
@RequestMapping(method = RequestMethod.GET, value = "/api/resource")
@Retryable(value = {FeignException.class}, maxAttempts = 3, backoff = @Backoff(delay = 1000))
@Headers("Connect-TimeOut:5000")
String getResource();
}
在 MyFeignClientConfiguration 类中配置超时和重试策略:
@Configuration
public class MyFeignClientConfiguration {
@Bean
public Request.Options options() {
return new Request.Options(5000, 10000); // 连接超时 5 秒,读取超时 10 秒
}
}
@RestController
public class ServiceAController {
@Autowired
private ServiceBClient serviceBClient;
@GetMapping("/consume")
public String consumeResourceFromB() {
return serviceBClient.getResource();
}
}
在上面代码中,通过配置超时和重试机制,OpenFeign 在调用远程服务时能够更好地处理超时和请求失败的情况。当调用 getResource() 方法时,OpenFeign 将会在 5 秒内等待响应,如果超时则抛出异常。同时,配置了最大重试次数为 3 次,每次重试间隔为 1 秒,以处理请求失败的情况。这样,OpenFeign 能够更加健壮地处理远程服务调用。