返回顶部
首页 > 资讯 > 后端开发 > Python >如何配置feign全局log
  • 345
分享到

如何配置feign全局log

2024-04-02 19:04:59 345人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录SpringBoot集成feign配置全局log概述设置Feign接口日志级别为FULLfeign常用配置Feign的组成首先如何整合Feign如何给Feign添加日志级别细粒度

springBoot集成feign配置全局log

概述

项目里使用了Feign进行远程调用,有时为了问题排查,需要开启请求和响应日志,下面简介一下如何开启Feign日志

设置Feign接口日志级别为FULL

在application.yml添加log配置

方式一: 在启动类路径设置debug级别的日志(推荐)

logging:
  level:
    com.example.demo: debug 

方式二: 在配置@FeignClien的类径设置debug级别的日志

logging:
  level:
    com.example.demo.feign.DemoFeignClient: debug 

配置feign的日志级别

方式一: 在application.yml配置(推荐)

feign.client.config.default.loggerLevel: full

方式二: 使用@Configuration配置类完成配置

@Configuration
public class FeignConfiguration {
  @Bean
  public Logger.Level level() { return Logger.Level.FULL; }
}

Feign日志级别

  • NONE,无记录(DEFAULT)。
  • BASIC,只记录请求方法和URL以及响应状态代码和执行时间。
  • HEADERS,记录基本信息以及请求和响应标头。
  • FULL,记录请求和响应的头文件,正文和元数据

feign常用配置

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配置

粒度RibbonFeign
代码局部@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注解,需注意父子上下文,线上修改需要重打包,发布
属性配置易上手配置更加直观线上修改无需重新打包,发布优先级更高极端场景下没有代码配置更加灵活

优先级:细粒度属性配置 > 细粒度代码配置 > 全局属性配置 > 全局代码配置

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 如何配置feign全局log

本文链接: https://lsjlt.com/news/151939.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何配置feign全局log
    目录SpringBoot集成feign配置全局log概述设置Feign接口日志级别为FULLfeign常用配置Feign的组成首先如何整合Feign如何给Feign添加日志级别细粒度...
    99+
    2024-04-02
  • Tomcat全局日志如何配置
    这篇文章主要介绍Tomcat全局日志如何配置,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Tomcat全局日志配置介绍如果我们在production环境中有许多web application, 一般来说我们都是每个a...
    99+
    2023-06-18
  • git如何取消全局配置
    这篇文章主要讲解了“git如何取消全局配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“git如何取消全局配置”吧!取消全局配置的方法:1、在终端执行“git config --global...
    99+
    2023-06-26
  • 如何用MyBatis全局配置文件
    这篇文章主要讲解了“如何用MyBatis全局配置文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用MyBatis全局配置文件”吧!目录MyBatis全局配置文件settings 设置t...
    99+
    2023-06-20
  • 如何配置Log日志
    这篇文章主要讲解了“如何配置Log日志”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何配置Log日志”吧!1.Slf4jSlf4j 的全称是 Simple...
    99+
    2024-04-02
  • 如何深入浅析小程序中的全局配置
    本篇文章给大家分享的是有关如何深入浅析小程序中的全局配置,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。全局配置文件及常用的配置项小程序根目录下的 app.json 文件是小程序...
    99+
    2023-06-28
  • 详谈Feign的配置类是如何生效的
    目录1. Feign1.1 配置类:ApiConfiguration.java1.2 FeignClientsRegistrar1.3 FeignAutoConfiguration1...
    99+
    2024-04-02
  • MyBatis全局配置文件详解
    目录MyBatis全局配置文件settings设置typeAliases类型命名存在的问题:@Alias("")environments环境transactionManager事务管...
    99+
    2024-04-02
  • 【微信小程序】全局配置
    目录 全局配置文件及常用的配置项 全局配置 - window 1. 小程序窗口的组成部分 2. 了解 window 节点常用的配置项  3. 设置导航栏的标题 4. 设置导航栏的背景色  5. 设置导航栏的标题颜色 6. 全局开启下拉刷新功...
    99+
    2023-09-10
    微信小程序 小程序 前端 javascript 开发语言
  • springboot全局配置文件与多环境配置的全过程
    目录1、全局配置文件2、多环境配置附:加载多环境配置总结1、全局配置文件 新建一个springboot项目它的resources目录下有一个application.propertie...
    99+
    2024-04-02
  • SocksCap64全局代理如何设置
    要设置SocksCap64全局代理,按照以下步骤操作:1. 下载并安装SocksCap64软件。2. 打开SocksCap64,在主...
    99+
    2023-08-23
    SocksCap64
  • jQuery如何设置全局动画设置?
    这篇文章将为大家详细讲解有关jQuery如何设置全局动画设置?,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 jQuery 提供了 $.fx.speeds 对象,用于设置全局动画设置。该对象包含以下属性...
    99+
    2024-04-02
  • SpringBoot2中如何配置系统全局异常映射处理
    这篇文章给大家分享的是有关SpringBoot2中如何配置系统全局异常映射处理的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、异常分类这里的异常分类从系统处理异常的角度看,主要分类两类:业务异常和系统异常。1、...
    99+
    2023-06-02
  • 【微信小程序】全局配置 - tabBar
    目录 全局配置 - tabBar 1. 什么是 tabBar 2. tabBar 的 6 个组成部分 3. tabBar 节点的配置项 4. 每个 tab 项的配置选项 全局配置 - 案例:配置 tabBar 1. 需求描述 2. 实现步骤...
    99+
    2023-09-03
    微信小程序 开发语言 小程序 javascript
  • Spring Boot DevTools全局配置的方法
    这篇文章主要讲解了“Spring Boot DevTools全局配置的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Spring Boot Dev...
    99+
    2023-06-29
  • app.json文件全局配置的方法
    本文小编为大家详细介绍“app.json文件全局配置的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“app.json文件全局配置的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。  app.json文件用...
    99+
    2023-06-26
  • 怎么对Mybatis进行全局配置
    这期内容当中小编将会给大家带来有关怎么对Mybatis进行全局配置,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。总体介绍:MyBatis实际上是Ibatis3.0版本以后的持久化层框架【也就是和数据库打交...
    99+
    2023-05-31
    mybatis
  • MySQL中如何设置全局变量
    这篇文章将为大家详细讲解有关MySQL中如何设置全局变量,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 ERROR 1418 (HY000): This ...
    99+
    2024-04-02
  • 电脑如何设置全局代理
    设置全局代理的方法因操作系统不同而有所不同,下面分别介绍 Windows 和 Mac 系统的设置方法。 Windows 系统: 打开 Internet 属性。点击“连接”标签,再点击“局域网设置”。在弹出的窗口中,选择“使用代理服务...
    99+
    2023-10-25
    网络 服务器 运维
  • vue如何在main.js中配置全局的通用公共组件
    目录在main.js中配置全局的通用公共组件vue.js全局组件的三种方式全局组件第一种方式,单引号(或双引号)第二种方式反引号第三种方式外部ID总结在main.js中配置全局的通用...
    99+
    2023-01-13
    vue main.js main.js配置公共组件 全局通用公共组件
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作