当前位置:首页 > 技术文章 > 正文内容

Spring Boot 中整合 Feign 客户端时,配置日志的多种方式

1. 配置日志级别

可以通过在application.properties或application.yml文件中设置 Feign 客户端接口的日志级别来控制日志输出。

application.properties 配置示例

# 设置Feign客户端日志级别,这里的com.example.client是Feign客户端接口所在的包名
logging.level.com.example.client=DEBUG

application.yml 配置示例

logging:
  level:
    com.example.client: DEBUG

2. 配置 Feign 日志记录器级别

在代码中配置 Feign 日志记录器的级别,这可以更细粒度地控制日志输出。

步骤

  1. 创建配置类:创建一个配置类来指定 Feign 日志记录器的级别。
logging:
  level:
    com.example.client: DEBUG

在上述代码中,Logger.Level 有以下几种可选值:

  • NONE:不记录任何日志。
  • BASIC:仅记录请求方法、URL、响应状态码和执行时间。
  • HEADERS:记录基本信息以及请求和响应的头信息。
  • FULL:记录请求和响应的头信息、正文和元数据。
  1. 在 Feign 客户端接口上使用配置类
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

@FeignClient(name = "example-service", configuration = FeignConfig.class)
public interface ExampleClient {

    @GetMapping("/example")
    String getExample();
}

3. 全局配置 Feign 日志

如果你想对所有的 Feign 客户端应用相同的日志配置,可以创建一个全局的配置类。

import feign.Logger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class GlobalFeignConfig {

    @Bean
    public Logger.Level feignLoggerLevel() {
        return Logger.Level.FULL;
    }
}

然后在application.properties或application.yml中指定全局配置类:

# application.properties
feign.client.default-to-properties=false
feign.client.config.default.loggerLevel=FULL
# application.yml
feign:
  client:
    default-to-properties: false
    config:
      default:
        loggerLevel: FULL

相关文章

gitlab简单搭建与应用(gitlab怎么用)

一、gitlab1、简介GitLab是利用Ruby on Rails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。与Github类似,GitLab...

GIT最佳实践,高效提升多团队协同开发效率

多个团队共同维护同一个微服务模块时,经常出现A团队已发布的功能,B团队提交测发布出现冲突或缺失,如何有效解决多团队共同维护的问题呢?常用的版本管理工具有GIT、SVN,这两种版本管理工具,各有千秋;虽...

配置GitLab流水线和门禁系统(gitlab工作流)

在项目开发的过程中,为了保证代码质量,我们会使用诸多代码质量检测工具,这些工具或是在本地,或是在云端,虽然工具可以检测出异常问题,但是这些问题还是需要我们程序员来修复,如果我们不强制所有人必须修复异常...

(在线编辑DWG)网页CAD二开实现焊接符号绘制

前言在工程制图和制造领域,焊接符号(Welding Symbols)是用于表示焊缝类型、尺寸、位置以及工艺要求的标准化图形语言。广泛应用于机械设计、钢结构、船舶制造、压力容器等行业中,帮助技术人员理解...

HTML5学习笔记三:HTML5语法规则(html5语法详解)

1.标签要小写2.属性值可加可不加””或”3.可以省略某些标签 html body head tbody4.可以省略某些结束标签 tr td li例:显示效果:5.单标签不用加结束标签img inpu...

HTML5设计与制作哪家强?全省50多所高职院校齐聚中山比拼

3月22日下午,2018-2019年广东省职业院校学生专业技能大赛“HTML5交互融媒体内容设计与制作”赛项在中山火炬职业技术学院开幕。全省51所高职院校的52支参赛队伍参加此次大赛。参赛师生将于3月...