【Spring Cloud】如何修改Feign的日志记录级别




前言

  • 本次示例代码的文件结构如下图所示。
    在这里插入图片描述

1. 介绍

  • Feign 允许我们自定义配置,下面是 Feign 可以修改的配置。

    类型作用说明
    feign.Logger.Level修改日志级别包含四种不同级别:NONE、BASIC、HEADERS、FULL
    feign.codec.Decoder响应结果的解析器HTTP 远程调用的结果做解析,例如解析 JSON 字符串反序列化成 Java 对象
    feign.codec.Encoder请求参数编码将请求参数编码,便于通过 HTTP 请求发送
    feign.Contract支持的注解格式默认是 Spring MVC 的注解
    feign.Retryer失败重试机制请求失败的重试机制,默认是没有,不过会使用 Ribbon 的重试
  • 一般我们需要配置日志级别。NONE 是不记录,BASIC 只记录基本的 HTTP 请求信息,HEADERS 除了基本的 HTTP 信息外,还记录请求头;而 FULL 则是记录完整的 HTTP 信息。换句话说,按日志完整程度从小到大排序为:NONE < BASIC < HEADERS < FULL 。

  • 实际开发中,推荐使用 BASIC 。因为记录日志会消耗一定的性能。


2. 方式一:配置文件


1)全局生效

  • order-service 的配置文件。
feign:
  client:
    config:
      default: # 全局生效,所有微服务生效
        logger-level: FULL
  • 重启 OrderApplication 生效,当在 Postman 发送了一次查询请求后, OrderApplication 的控制台就出现了全部的 HTTP 日志信息。

    image-20230213124643902


2)局部生效

feign:
  client:
    config:
      userservice: # 只在远程调用userservice这个微服务时才生效
        logger-level: FULL

3. 方式二:Java代码

  • OrderApplication 中创建 Feign 配置类 config/DefaultFeignConfiguration.java ,声明 Bean 。

    public class DefaultFeignConfiguration {
    
        @Bean
        public Logger.Level loggerLevel() {
            return Level.BASIC;
        }
        
    }
    
  • 该类没有被 Spring 容器管理,因此不会生效。还需要进行下面的配置才能生效。


1)全局配置

  • 在启动类的 @EnableFeignClients 注解上添加参数,指定 Feign 的配置类。

    @EnableFeignClients(defaultConfiguration = DefaultFeignConfiguration.class)
    

2)局部配置

  • 放到 Feign 客户端接口的注解 @FeignClient 之中。

    @FeignClient(value = "userservice", configuration = DefaultFeignConfiguration.class)
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

自牧君

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

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

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

打赏作者

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

抵扣说明:

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

余额充值