返回目录
https://blog.csdn.net/BW_Bear/article/details/88746646
Hystrix 监控可视化.note源码位置:
微服务注册管理:
https://github.com/zhaowei-zhang/CloudTest/tree/master/使用Hystrix实现容错/microservice-discovery-eureka
生产者:
https://github.com/zhaowei-zhang/CloudTest/tree/master/使用Hystrix实现容错/microservice-provider-user
回退原因项目:
https://github.com/zhaowei-zhang/CloudTest/tree/master/使用Hystrix实现容错/microservice-consumer-movie-feign-hystrix-fallback-factory
在很多场景下,需要了解回退原因,便于故障排查
对于Feign方式如何获取回退原因
1.创建回退工厂类
@Component
class FeignClientFallbackFactory implements FallbackFactory<UserFeignClient>{
@Override
public UserFeignClient create(Throwable throwable) {
return new UserFeignClient() {
@Override
public User findById(Long id) {
System.err.println("进入回退方法,回退原因:"+throwable);
User user = new User();
user.setId(-1L);
user.setUsername("游客");
return user;
}
};
}
}
2.修改Feign接口属性
@FeignClient(name = "MICROSERVICE-PROVIDER-USER",
fallbackFactory = FallbackFactory.class)
public interface UserFeignClient {
@RequestMapping(value = "/{id}",method = RequestMethod.GET)
public User findById(@PathVariable("id")Long id);
}
3.测试
启动eureka服务、生产者服务、消费者服务;
通过消费者服务接口调用,正常显示数据
关闭生产者服务,
再次通过消费这服务接口调用,显示回退数据
4.回退工厂方式也可以用来实现不同异常不同回退
例如
@Component
class FeignClientFallbackFactory implements FallbackFactory<UserFeignClient>{
@Override
public UserFeignClient create(Throwable throwable) {
return new UserFeignClient() {
@Override
public User findById(Long id) {
System.err.println("进入回退方法,回退原因:"+throwable);
User user = new User();
if(throwable instanceof IllegalArgumentException){
user.setId(-1L);
}else{
user.setId(-2L);
}
user.setUsername("游客");
return user;
}
};
}
}
5.在某些情况下,不想用断路器包裹Feign所有方法,这样虽然方便,单很多场景并不需要该功能
5.1先设定自定义配置类
@Configuration
public class FeignDisableHystrixConfiguration {
@Bean
@Scope("prototype")
public Feign.Builder feignBuilder(){
return Feign.builder();
}
}
5.2在接口类中设定
@FeignClient(name = "MICROSERVICE-PROVIDER-USER",
configuration = FeignDisableHystrixConfiguration.class)
public interface UserFeignClient {
@RequestMapping(value = "/{id}",method = RequestMethod.GET)
public User findById(@PathVariable("id")Long id);
}