Feign方式使用Hystrix,通过FallbackFactory检查回退原因

返回目录

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{
    @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服务、生产者服务、消费者服务;
通过消费者服务接口调用,正常显示数据
Feign方式使用Hystrix,通过FallbackFactory检查回退原因_第1张图片
关闭生产者服务,
再次通过消费这服务接口调用,显示回退数据

Feign方式使用Hystrix,通过FallbackFactory检查回退原因_第2张图片
Feign方式使用Hystrix,通过FallbackFactory检查回退原因_第3张图片

4.回退工厂方式也可以用来实现不同异常不同回退

例如

@Component
class FeignClientFallbackFactory implements FallbackFactory{
    @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);
}

返回目录

https://blog.csdn.net/BW_Bear/article/details/88746646

你可能感兴趣的:(SpringCloud)