美文网首页
Spring Cloud全解析:服务调用之Feign与Hystr

Spring Cloud全解析:服务调用之Feign与Hystr

作者: 墨线宝 | 来源:发表于2024-09-23 10:07 被阅读0次

Feign与Hystrix

Feign默认已经整合了hystrix,只是默认是没有启用的,需要进行配置

feign:
  hystrix:
    enabled: true

可以看到如果配置了feign.hystrix.enabled会使用HystrixFeign.builder()来构建Feign,将具体的调用包裹在HystrixCommand 中

@Configuration(proxyBeanMethods = false)
@ConditionalOnClass({ HystrixCommand.class, HystrixFeign.class })
protected static class HystrixFeignConfiguration {

   @Bean
   @Scope("prototype")
   @ConditionalOnMissingBean
   @ConditionalOnProperty(name = "feign.hystrix.enabled")
   public Feign.Builder feignHystrixBuilder() {
      return HystrixFeign.builder();
   }

}

和 Feign 使用的时候需要注意错误处理的问题。对于一些非功能性的业务错误,需要包装为 HystrixBadRequestException,让 Hystrix 不要统计到错误中造成断路

虽然开启了hystrix,但是其默认不带有监控端点,如果想要使用监控端点,需要加依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>

然后启动类上增加@EnableCircuitBreaker注解,并开启端点

management:
  endpoints:
    web:
      exposure:
        include: 'hystrix.stream'

参考文献

相关文章

网友评论

      本文标题:Spring Cloud全解析:服务调用之Feign与Hystr

      本文链接:https://www.haomeiwen.com/subject/zpaxrjtx.html