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

news/2025/3/21 11:12:39/

本期目录

  • 前言
  • 1. 介绍
  • 2. 方式一:配置文件
    • 1)全局生效
    • 2)局部生效
  • 3. 方式二:Java代码
    • 1)全局配置
    • 2)局部配置



前言

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

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 {@Beanpublic Logger.Level loggerLevel() {return Level.BASIC;}}
    
  • 该类没有被 Spring 容器管理,因此不会生效。还需要进行下面的配置才能生效。


1)全局配置

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

    @EnableFeignClients(defaultConfiguration = DefaultFeignConfiguration.class)
    

2)局部配置

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

    @FeignClient(value = "userservice", configuration = DefaultFeignConfiguration.class)
    

http://www.ppmy.cn/news/24538.html

相关文章

记一次 .NET 某游戏网站 CPU爆高分析

一&#xff1a;背景 1. 讲故事 这段时间经常有朋友微信上问我这个真实案例分析连载怎么不往下续了&#xff0c;关注我的朋友应该知道&#xff0c;我近二个月在研究 SQLSERVER&#xff0c;也写了十多篇文章&#xff0c;为什么要研究这东西呢&#xff1f; 是因为在 dump 中发现…

operator的两种用法(重载和隐式类型转换)

文章目录重载隐式类型转换构造函数的隐式类型转换补充operator算子的隐式类型转换重载 略 隐式类型转换 构造函数的隐式类型转换 利用operator进行的隐式类型转换成为operator算子的隐式类型转换&#xff0c;讲这个之前先了解构造函数的隐式类型转换&#xff0c;请看以下代…

使用继承与派生的6大要点

概述 面向对象编程技术非常看重软件的可重用性&#xff0c;在C中&#xff0c;可重用性是通过继承机制来实现的。继承机制允许程序员在保持原有类的数据和功能的基础上进行扩展&#xff0c;增加新的数据和功能&#xff0c;从而构成一个新的类&#xff0c;也称为派生类。原有类&a…

Java类和对象超详细整理,适合新手入门

目录 一、驼峰命名法 二、Java注释 三、转义符 四、Java程序它的基本结构是什么&#xff1f; 五、Java中的类 六、创建类 七、定义main方法 八、执行代码输出语句 九、Java中的对象 十、创建对象 十一、类与对象的关系 一、驼峰命名法 包名&#xff1a;多单词组成所…

别具一格,原创唯美浪漫情人节表白专辑,(复制就可用)(html5,css3,svg)表白爱心代码(1)

别具一格&#xff0c;原创唯美浪漫情人节表白专辑&#xff0c; (复制就可用)&#xff08;html5,css3,svg)表白爱心代码(1) 一、 前言 回眸之间&#xff0c;丰盈了岁月&#xff0c;涟漪了思绪&#xff0c;轻轻落笔&#xff0c;不写伤痕&#xff0c;不写仇怨&#xff0c;只写岁月…

JAVA集合专题4 —— Map

目录Map接口实现类的特点Map接口的常见方法Map六大遍历方式Map练习1code编程练习2code编程练习3思路codeMap接口实现类的特点 Map与Collection并列存在&#xff0c;是Map集合体系的顶级接口Map的有些子实现存储数据是有序的(LinkedHashMap)&#xff0c;有些子实现存储数据是无…

前端高频面试题—JavaScript篇(二)

&#x1f4bb;前端高频面试题—JavaScript篇&#xff08;二&#xff09; &#x1f3e0;专栏&#xff1a;前端面试题 &#x1f440;个人主页&#xff1a;繁星学编程&#x1f341; &#x1f9d1;个人简介&#xff1a;一个不断提高自我的平凡人&#x1f680; &#x1f50a;分享方向…

[多线程进阶]CAS与Synchronized基本原理

专栏简介: JavaEE从入门到进阶 题目来源: leetcode,牛客,剑指offer. 创作目标: 记录学习JavaEE学习历程 希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长. 学历代表过去,能力代表现在,学习能力代表未来! 目录: 1.CAS 1.1 什么是CAS? 1.2 CAS伪代码 1.3 CAS …