Spring Cloud全解析:服务调用之自定义Feign的配置

自定义Feign的配置

Feign的默认配置类是FeignClientsConfiguration,其内部定义了Feign默认使用的编码器、解码器、契约、重试机制等

@Bean
@ConditionalOnMissingBean
public Decoder feignDecoder() {
  // 解码器,将字节数组反序列化为方法返回值类型的对象,默认只支持反序列化为String和byte[]
  // SpringDecoder使用消息解析器可以支持任意类型
   return new OptionalDecoder(
         new ResponseEntityDecoder(new SpringDecoder(this.messageConverters)));
}

@Bean
@ConditionalOnMissingBean
@ConditionalOnMissingClass("org.springframework.data.domain.Pageable")
public Encoder feignEncoder() {
  // 编码器,将请求体对应的方法参数序列化为字节数组,默认的只支持参数为String和byte[]
  // SpringEncoder可以将任意方法参数序列化
   return new SpringEncoder(this.messageConverters);
}

@Bean
@ConditionalOnMissingBean
public Contract feignContract(ConversionService feignConversionService) {
  // Contract的作用是解析方法上的注解和参数,构建Http请求需要用到的基本参数
  // SpringMvcContract使得Feign能够识别SpringMvc的注解
  return new SpringMvcContract(this.parameterProcessors, feignConversionService);
}

@Bean
@ConditionalOnMissingBean
public Retryer feignRetryer() {
  return Retryer.NEVER_RETRY;
}

但是有时候默认的并不满足全部的场景,我们需要自定义来进行配置,可以通过@FeignClient注解中的configuration属性来配置自定义的feign配置类,其优先级高于FeignClientsConfiguration

自定义Feign

@Configuration
public class FeignConfiguration {

 /**
  * 使用feign的原生注解
  * 
  * @author zhanghe
  * @return feign的使用形式
  */

 @Bean
 public Contract feignContract() {
  log.debug("原生feign  [bean注册]");
  return new feign.Contract.Default();
 }

 /**
  * 公共错误回调
  * @return 错误回调
  */

 @Bean
 public FallBackImpl fallBackImpl() {
  return new FallBackImpl();
 }
}

如果该配置类为该项目下所有feign共用的,那么该类需要在@componentScan扫描下,这样就可以覆盖原本的默认配置,如果不希望该配置共用,只是个别feign使用,则该类不可以在@componentScan扫描下,而是要在所需要的feign中单独进行配置@FeignClient(configuration=FeignConfiguration.class)

参考文献

  • 自定义Feign的配置


原文始发于微信公众号(bug生产基地):Spring Cloud全解析:服务调用之自定义Feign的配置

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/301694.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!