In Spring Cloud, Feign and Ribbon may fail the first call after integrating Hystrix. How do you solve this problem?
why
Hystrix’s default timeout is 1 second, and if there is no response after this time, the fallback code will be entered. The first request tends to be slow (some classes need to be instantiated due to Spring’s lazy loading mechanism), and the response time can be greater than a second. Once we know why, we’ll figure it out and let you go. There are three solutions, taking Feign as an example.
Method 1: Set the Hystrix timeout length
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000
Copy the code
The configuration is to change Hystrix’s timeout to 5 seconds, which is the easiest thing to think of, but a bit of a band-aid.
Method 2: Disable Hystrix timeout
hystrix.command.default.execution.timeout.enabled: false
Copy the code
This parameter is used to disable Hystrix timeout. It is not recommended.
Method 3: Disable Hystrix for Feign
Global disable
feign.hystrix.enabled: false
Copy the code
Simply disable Feign’s Hystrix, which is extreme and not recommended except in some special situations.
Local disabled
Disable Hystrix for the Feign Client named microservice-provider-user
@FeignClient(name = "microservice-provider-user")
public interface UserFeignClient {
@GetMapping("/users/{id}")
User findById(@PathVariable("id") Long id);
}
class FooConfiguration {
@Bean
@Scope("prototype")
public Feign.Builder feignBuilder() {returnFeign.builder(); }}Copy the code
Method 4. Ribbon Configuration hunger loading (best)
Starting with Dalston, the Ribbon supports configuring the Eager Load implementation to initialize Ribbon related classes at startup.
ribbon:
eager-load:
enabled: true
clients: client1, client2, client3
Copy the code
The previous version of Dalson can implement eager Load through some Hack mechanisms, but the cost is slightly higher, so I will not post here.
Link to this article: www.itmuch.com/spring-clou…