https://blog.csdn.net/2401_82884096/article/details/138620659

OpenFeign 允许配置超时重试机制,以便在调用远程服务时能够更好地处理网络异常和服务不可用的情况。

1. 超时机制

通过配置连接超时和读取超时,可以控制 OpenFeign 在发起请求后等待响应的时间。如果在指定的超时时间内未收到响应,OpenFeign 将抛出超时异常。

2. 重试机制

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 能够更加健壮地处理远程服务调用。