zhangxp2006 2023-06-11 22:11 采纳率: 0%
浏览 14

如何使用openfeign不能进行服务降级?(语言-java)

使用springboot3.0.6,使用openfeign4.0.2进行远程调用服务降级没有效果,正常远程调用是可以的,但是把服务器停掉后却不能调用服务降级。
报错:feign.FeignException$ServiceUnavailable: [503] during [GET] to [http://userservice/getusers] [UserCilent#getUsers()]: [Load balancer does not contain an instance for the service userservice]

img

 文件           编辑           查看
 @SpringBootApplication
 @EnableDiscoveryclient
 @EnableFeignclients
 public class BorrowserviceApplication
      public static void main(stringl]args){
            SpringApplication.run(BorrowserviceApplication.class,args)
 @component
 @Feignciient(name = "bookservice"fallback = Bookclientimpl.class)
 public interface Bookclient
            @GetMapping"/getbooks")
            public List<Book> getBooks()
            @GetMapping("/getbook/id")
            public Book getbook(@Pathvariable"id") int id)
 @component
 public class BookclientImpl implements Bookclient
      @override
      public List<Book> getBooks()
            return null;
      @override
      public Book getbook(int id)
      Y
            returnnewBook(e,我错了W);
 行33,列2
  • 写回答

4条回答 默认 最新

  • 卑微的Coder 2023-06-11 23:09
    关注

    OpenFeign并不直接支持服务降级,但可以通过以下方式实现:

    Hystrix:Hystrix是Netflix开源的一款容错框架,可以实现服务降级、熔断、限流等功能。在OpenFeign中,可以通过添加Hystrix依赖并配置FeignClient的fallback属性来实现服务降级。

    Ribbon:Ribbon是Netflix开源的一款负载均衡框架,可以实现服务发现和负载均衡。在OpenFeign中,可以通过配置FeignClient的fallbackFactory属性来实现服务降级。

    自定义实现:可以自定义实现服务降级的逻辑,例如在调用失败时返回默认值、记录日志等。

    需要注意的是,服务降级并不是必须的,而是根据具体业务场景而定。在一些关键业务场景下,服务降级可以提高系统的可用性和稳定性。

    评论

报告相同问题?

问题事件

  • 创建了问题 6月11日

悬赏问题

  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起
  • ¥15 msix packaging tool打包问题
  • ¥15 finalshell节点的搭建代码和那个端口代码教程
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据
  • ¥20 软件测试决策法疑问求解答