Spring Cloud Feign组成配置过程解析

 更新时间:2020年03月04日 11:00:37   作者:赵小胖0914  
这篇文章主要介绍了Spring Cloud Feign组成配置过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

Feign的组成

接口
作用
默认值
Feign.Builder
Feign的入口
Feign.Builder
Client
Feign底层用什么去请求
和Ribbon配合时:LoadBalancerFeignClient
不和Ribbon配合时:Fgien.Client.Default
Contract
契约,注解支持
SpringMVCContract
Encoder
解码器,用于将独享转换成HTTP请求消息体
SpringEncoder
Decoder
编码器,将相应消息体转成对象
ResponseEntityDecoder
Logger
日志管理器
Slf4jLogger
RequestInterceptor
用于为每个请求添加通用逻辑(拦截器,例子:比如想给每个请求都带上heared)

Feign的日记级别

日志级别
打印内容
NONE(默认)
不记录任何日志
BASIC
仅记录请求方法,URL,响应状态代码以及执行时间(适合生产环境)
HEADERS
记录BASIC级别的基础上,记录请求和响应的header
FULL
记录请求和弦ineader,body和元数据

首先如何整合Feign

遵循SpringBoot的三板斧第一步:加依赖

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

第二步:写注解

@EnableFeignClients //在启动类上加

第三步:写配置

如何给Feign添加日志级别

细粒度

方式一:代码实现第一步:添加Feign配置类,可以添加在主类下,但是不用添加@Configuration。如果添加了@Configuration而且又放在了主类之下,那么就会所有Feign客户端实例共享,同Ribbon配置类一样父子上下文加载冲突;如果一定添加@Configuration,就放在主类加载之外的包。建议还是不用加@Configuration。

public class FeignConfig {
  @Bean
  public Logger.Level Logger() {
    return Logger.Level.FULL;
  }
}

第二步:给@FeignClient添加配置类

//@FeignClient configuration = GoodsFeignConfig.class 细粒度配置,指定配置类
@FeignClient(name = "goods", configuration = FeignConfig.class)

第四步:写配置

logging:
 level:
  com.xxx.xxx.FeignAPI: DEBUG #需要将FeignClient接口全路径写上# 开启日志 格式为logging.level. Feign客户端路径

方式二:配置属性实现

feign:
 client:
  config:
   #想要调用的微服务名称
   server-1:
    loggerLevel: FULL

全局配置

方式一:代码实现添加了@Configuration放在了主类之下,那么就会所有Feign客户端实例共享,同Ribbon配置类一样父子上下文加载冲突;让父子上下文ComponentScan重叠(强烈不建议)唯一正确方式

//在启动类上为@EnableFeignClients注解添加defaultConfiguration配置
@EnableFeignClients(defaultConfiguration = FeignConfig.class)

方式二:配置属性实现

feign:
 client:
  config:
   #将调用的微服务名称改成default就配置成全局的了
   default:
    loggerLevel: FULL

Feign支持的配置项

代码方式

配置项
作用
Logger.Level
指定日志级别
Retryer
指定重试策略
ErrorDecoder
指定错误解码器
Request.Options
超时时间
Collection
拦截器
SetterFactory
用于设置Hystrix的配置属性,Fgien整合Hystrix才会用

配置属性

feign:
 client:
  config:
   feignName:
    connectTimeout: 5000 # 相当于Request.Optionsn 连接超时时间
    readTimeout: 5000   # 相当于Request.Options 读取超时时间
    loggerLevel: full   # 配置Feign的日志级别,相当于代码配置方式中的Logger
    errorDecoder: com.example.SimpleErrorDecoder # Feign的错误解码器,相当于代码配置方式中的ErrorDecoder
    retryer: com.example.SimpleRetryer # 配置重试,相当于代码配置方式中的Retryer
    requestInterceptors: # 配置拦截器,相当于代码配置方式中的RequestInterceptor
     - com.example.FooRequestInterceptor
     - com.example.BarRequestInterceptor
    # 是否对404错误解码
    decode404: false
    encode: com.example.SimpleEncoder
    decoder: com.example.SimpleDecoder
    contract: com.example.SimpleContract

Feign还支持对请求和响应进行GZIP压缩,以提高通信效率,配置方式如下:

# 配置请求GZIP压缩
feign.compression.request.enabled=true
# 配置响应GZIP压缩
feign.compression.response.enabled=true
# 配置压缩支持的MIME TYPE
feign.compression.request.mime-types=text/xml,application/xml,application/json
# 配置压缩数据大小的下限
feign.compression.request.min-request-size=2048

Ribbon配置 VS Feign配置

粒度
Ribbon
Feign
代码局部
@RibbonClient(configuration=RibbonConfig.class),RibbonConfig类必须加@Configuration,且必须放在父上下文无法扫到的包下
@FeignClient(configuration=FeignConfig.class),FeignConfig类的@Configuration可以不加(可选),如果有,必须放在父上下文无法扫到的包下
代码全局
@RibbonClients(defaultConfigurtion=RibbonConfig.class)
@EnableFeignClients(defaultConfiguration = FeignConfig.class)
...
配置属性局部
.ribbon.NFLoadBalancerClassName
...
feign.client.config..loggerLevel 
...
配置属性全局
feign.client.config.default.loggerLevel

Feign 代码方式 VS 配置属性方式

配置方式
有点
缺点
代码配置
基于代码,更加灵活
如果Feign的配置类加了@Configuration注解,需注意父子上下文,线上修改需要重打包,发布
属性配置
易上手
配置更加直观
线上修改无需重新打包,发布
优先级更高
极端场景下没有代码配置更加灵活

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot项目中Date类型数据在接口返回的时间不正确的问题解决

    SpringBoot项目中Date类型数据在接口返回的时间不正确的问题解决

    如果接口返回的Date类型时间与数据库中datetime不一致,可能是由于没有正确配置时区导致的,解决方法是在yaml配置文件中指定正确的日期格式和时区配置,修改配置并重启项目后,可以获得正确的时间,下面就来介绍一下
    2024-09-09
  • 一文掌握Spring中循环依赖与三级缓存

    一文掌握Spring中循环依赖与三级缓存

    这篇文章主要介绍了Spring中循环依赖与三级缓存,Spring通过三级缓存解决了循环依赖,其中一级缓存为单例池,二级缓存为早期曝光对象earlySingletonObjects,三级缓存为早期曝光对象工厂(singletonFactories),本文结合实例代码介绍的非常详细,需要的朋友参考下吧
    2023-09-09
  • Java对象的XML序列化与反序列化实例解析

    Java对象的XML序列化与反序列化实例解析

    这篇文章主要介绍了Java对象的XML序列化与反序列化实例解析,小编觉得还是挺不错的,这里分享给大家。
    2017-10-10
  • FactoryBean BeanFactory方法使用示例详解讲解

    FactoryBean BeanFactory方法使用示例详解讲解

    这篇文章主要为大家介绍了FactoryBean BeanFactory方法使用示例详解讲解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • mybatis-plus更新字段为null的处理方式

    mybatis-plus更新字段为null的处理方式

    这篇文章主要介绍了mybatis-plus更新字段为null的处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • mybatis利用association或collection传递多参数子查询

    mybatis利用association或collection传递多参数子查询

    今天小编就为大家分享一篇关于mybatis利用association或collection传递多参数子查询,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • 使用Java获取linux和window序列号

    使用Java获取linux和window序列号

    这篇文章主要为大家详细介绍了如何使用Java获取Windows和Linux系统上的CPU序列号、磁盘、mac地址等信息,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-01-01
  • java操作elasticsearch详细方法总结

    java操作elasticsearch详细方法总结

    elasticsearch是使用Java编写的一种开源搜索引擎,也是一种分布式的搜索引擎架构,这篇文章主要给大家介绍了关于java操作elasticsearch的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • Spring对事务管理的支持

    Spring对事务管理的支持

    今天小编就为大家分享一篇关于Spring对事务管理的支持,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • 解决java字符串转换成时间Unparseable date出错的问题

    解决java字符串转换成时间Unparseable date出错的问题

    这篇文章主要介绍了解决java字符串转换成时间Unparseable date出错的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06

最新评论