今天在模拟服务A调用服务B时,如果服务B发生异常,服务A触发熔断降级时,发生一个问题,那就是我在服务A配置的fallback死活不生效。
pom文件该配置的hystrix依赖也配置了
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> <version>2.2.1.RELEASE</version> </dependency>
我在服务B模拟了一个异常
按照我的理解,这个时候服务A肯定会触发熔断,执行fallback的方法,控制台打印我写的测试语句
但是控制台缺报了500的异常。我百思不得其解,该配置的都配置了,应该会正常执行fallback啊。带着疑问,我去了网上搜了下,网上说hystrix熔断默认是关闭的,需要手动开启。需要在配置文件中配置
feign: hystrix: enabled: true
我恍然大悟,这不很简单吗,我三下五除二就粘贴好了,开始重启服务,postman请求接口,内心十分的激动,马上就要见到光明了,postman执行的很快,控制台打印的也很快,我的心凉的更快。它并没有成功,我并不放弃,继续在网上遨游,看别人写的案例,发现都是千篇一律,都是让配置feign: hystrix: enabled: true。但是我发现了一个问题,这个配置在我的项目中是灰色的,好像我的项目并不支持这个配置
我带着好奇去网上搜索了这个配置。不同的springCloud版本配置的方式不同。
SpringCloud 2020之前的版本,配置feign.hystrix.enabled=true
SpringCloud 2020之后的版本,feign.hystrix.enabled=true无法解析,配置feign.circuitbreaker.enabled=true。
我赶忙了把配置改成了feign.circuitbreaker.enabled=true
重启项目,fallback执行生效。