第二步:写注解
@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才会用 |










