SpringCloud修改Feign日志记录级别过程浅析

 更新时间:2023年02月15日 11:00:35   作者:自牧君  
OpenFeign源于Netflix的Feign,是http通信的客户端。屏蔽了网络通信的细节,直接面向接口的方式开发,让开发者感知不到网络通信细节。所有远程调用,都像调用本地方法一样完成

前言

本次示例代码的文件结构如下图所示。

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 日志信息。

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)

到此这篇关于SpringCloud修改Feign日志记录级别过程浅析的文章就介绍到这了,更多相关SpringCloud修改Feign日志内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot多模块打包部署Docker的项目实战

    SpringBoot多模块打包部署Docker的项目实战

    本文通过介绍最常见的Maven管理的Spring Boot项目多模块打包部署Docker来介绍一下项目部署过程中操作流程和几个需要注意的点,具有一定的参加价值,感兴趣的可以了解一下
    2023-08-08
  • 使用Java代码实现Redis和数据库数据同步

    使用Java代码实现Redis和数据库数据同步

    这篇文章主要介绍了使用Java代码实现Redis和数据库数据同步问题,文中通过代码示例给大家讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-06-06
  • SpringBoot中的异常处理与参数校验的方法实现

    SpringBoot中的异常处理与参数校验的方法实现

    这篇文章主要介绍了SpringBoot中的异常处理与参数校验的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Java线程池的简单使用方法实例教程

    Java线程池的简单使用方法实例教程

    线程的使用在java中占有极其重要的地位,在jdk1.4极其之前的jdk版本中,关于线程池的使用是极其简陋的,在jdk1.5之后这一情况有了很大的改,这篇文章主要给大家介绍了关于Java线程池的简单使用方法,需要的朋友可以参考下
    2021-10-10
  • spring框架配置实体类复杂属性注入xml文件过程详解

    spring框架配置实体类复杂属性注入xml文件过程详解

    这篇文章主要介绍了spring框架配置实体类复杂属性注入xml文件过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • Springboot如何设置过滤器及重复读取request里的body

    Springboot如何设置过滤器及重复读取request里的body

    这篇文章主要介绍了Springboot如何设置过滤器及重复读取request里的body,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • JavaWeb简单用户登录注册实例代码(有验证码)

    JavaWeb简单用户登录注册实例代码(有验证码)

    这篇文章主要介绍了JavaWeb简单用户登录注册实例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • 基于Java中最常用的集合类框架之HashMap(详解)

    基于Java中最常用的集合类框架之HashMap(详解)

    下面小编就为大家带来一篇基于Java中最常用的集合类框架之HashMap(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • 浅谈Java线程Thread之interrupt中断解析

    浅谈Java线程Thread之interrupt中断解析

    这篇文章主要介绍了Java线程Thread之interrupt中断解析,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Java常用时间工具类总结(珍藏版)

    Java常用时间工具类总结(珍藏版)

    这篇文章主要为大家详细介绍了Java中一些常用时间工具类的使用示例代码,文中的代码简洁易懂,对我们学习Java有一定帮助,需要的可以参考一下
    2022-07-07

最新评论