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<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);
}

返回目录

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误是因为无法找到名为 "feign/hystrix/FallbackFactory.class" 的类路径资源,所以会报错。 这可能是因为您的项目缺少了相应的依赖或配置文件。根据引用的描述,您提到的 spring.xml 配置文件可能位于 resource 目录下,但您的项目中可能没有正确加载该资源。 根据引用的描述,您可能需要导入 Feign 相关的依赖包。确保您的项目中已经添加了以下依赖: ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 请仔细检查您的项目配置和依赖是否正确,并确保所需的类路径资源存在于正确的位置。如果问题仍然存在,请检查文件路径或联系相关开发人员进行进一步的调试和解决。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [解决报错class path resource [spring.xml] cannot be opened because it does not exist......](https://blog.csdn.net/qq_42490860/article/details/129534982)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [SpringCloud启动Provider微服务时出现java.io.FileNotFoundException异常](https://blog.csdn.net/qq_46010154/article/details/111250624)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值