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)

参考文献

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拾光师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值