相关推荐recommended
高版本Spring Cloud中OpenFeign整合Hystrix熔断降级不生效的问题及解决方案
作者:mmseoamin日期:2024-02-20

摘要

本文将介绍在使用高版本Spring Cloud(2020.0.x及以后),由于取消了Hystrix的集成,导致OpenFeign与Hystrix熔断降级不生效的问题。同时,也将给出解决该问题的方案,即添加feign.circuitbreaker.enabled=true配置。

正文

1. 背景

随着Spring Cloud框架的发展,高版本Spring Cloud(2020.0.x及以上)中取消了对Hystrix的集成和支持。这对之前依赖于Hystrix进行服务熔断和降级的项目带来了一些困扰,特别是在使用OpenFeign进行远程调用时。

2. 问题描述

在高版本Spring Cloud(2020.0.x及以上)中,原先使用OpenFeign与Hystrix进行熔断降级的配置方式已经失效。具体来说,之前常用的配置项"feign.hystrix.enabled"被移除,无法再通过该配置项来启用Hystrix相关功能

2.1 症状

在忽略版本迁移的情况下,使用高版本Spring Cloud通过OpenFeign进行服务调用时,发现Hystrix的熔断降级策略不起作用,即使配置了相关的降级逻辑,也无法触发。

2.2 原因分析

主要原因是,自Spring Cloud 2020.0.0版本开始,已移除相关的Netflix OSS组件,自然就不再默认集成Hystrix,取消了对Hystrix的自动装配。因此,导致配置项`feign.hystrix.enabled`不再生效。

2020.0.0版本前,只需在启动类上添加@EnableHystrix注解,OpenFeign的熔断降级功能便可生效,因为@EnableHystrix注解中引用了@EnableCircuitBreaker注解,默认开启了熔断降级功能。而在2020.0.0版本后,@EnableCircuitBreaker注解已被废弃:

高版本Spring Cloud中OpenFeign整合Hystrix熔断降级不生效的问题及解决方案,第1张

且在spring-configuration-metadata.json文件中找不到hystrix相关配置:

高版本Spring Cloud中OpenFeign整合Hystrix熔断降级不生效的问题及解决方案,第2张

3. 解决方案

为了解决高版本Spring Cloud中OpenFeign整合Hystrix熔断降级不生效的问题,我们需要手动添加配置来启用Circuit Breaker模块。

具体解决方案如下:

3.1 添加依赖

首先,在项目的构建文件(例如Maven的pom.xml)中添加以下依赖:


    org.springframework.cloud
    spring-cloud-starter-openfeign


    org.springframework.cloud
    spring-cloud-starter-netflix-hystrix

3.2 配置开关

在项目的配置文件(例如application.yml或application.properties)中添加以下配置项:

feign:
  circuitbreaker:
    enabled: true

该配置项用于启用OpenFeign的Circuit Breaker模块,从而替代了之前的Hystrix。

3.3 编写熔断降级逻辑

在需要进行熔断降级处理的Feign客户端接口上,添加`@FeignClient`注解,并在`fallback`属性中指定对应的Fallback类(实现Feign客户端接口)。示例代码如下:

@FeignClient(name = "service-name", fallback = MyFallback.class)
public interface MyFeignClient {
    @GetMapping("/api/endpoint")
    String getEndpoint();
}
@Component
public class MyFallback implements MyFeignClient {
    
    @Override
    public String getEndpoint() {
        return "触发服务降级";
    }
}

4. 结论

通过以上的解决方案,我们可以在高版本Spring Cloud中成功启用OpenFeign的熔断降级功能,替代了取消的Hystrix集成。通过手动配置`feign.circuitbreaker.enabled`,并编写相应的降级逻辑,我们可以继续在项目中使用熔断降级策略,确保系统的稳定性。