首页 文章资讯内容详情

SpringCloud组件:Feign之日志输出

2026-06-01 4 花语

本文内容纲要:

-Feign之日志输出 -Feign日志输出说明 -前期准备 -构建项目 -tairan-spring-cloud-feign-logger配置 -源码位置

目录

Feign之日志输出 Feign日志输出说明 前期准备 构建项目 tairan-spring-cloud-feign-logger配置 源码位置

Feign之日志输出

在我们日常开发过程中,经常会查看日志解决问题,那么Feign是不是也有日志输出呢?

答案:是的。

在构建@FeignClient注解修饰的服务客户端时,会为每一个客户端都创建一个Feign.Logger实例,可以利用该日志对象的Debug模式来分析Feign的请求细节。

环境配置如下: SpringBoot:2.1.1.RELEASE SpringCloud:Greenwich.RC1 Java:1.8 Maven:3.5.2

Feign日志输出说明

Feign的Level日志级别配置默认是:NONE,不要跟log日志混淆。

日志级别枚举类Logger.Level: NONE:不输出日志 BASIC:输出请求方法、URL、响应状态码、执行时间 HEADERS:基本信息以及请求和响应头 FULL:请求和响应的heads、body、metadata,建议使用这个级别

前期准备

一个服务注册中心spring-cloud-eureka,端口8761。 创建tairan-spring-cloud-feign-api核心工程,对外提供api接口。 创建服务提供者tairan-spring-cloud-feign-privder工程,提供/hello接口,端口为10001,并注册到服务中心。参考SpringCloud组件:将微服务提供者注册到Eureka服务中心 创建服务消费者tairan-spring-cloud-feign-logger工程,提供/feign-hello接口,端口号为10003,并注册到服务中心。参考SpringCloud组件:将微服务提供者注册到Eureka服务中心

构建项目

同样的是采用idea开发工具创建一个SpringBoot项目,在依赖选择界面对应的添加Web、Feign以及EurekaDiscovery依赖,直接完成创建项目。

项目的pom.xml内容如下所示: <artifactId>tairan-spring-cloud-feign-logger</artifactId> <name>tairan-spring-cloud-feign-logger</name> <description>DemoprojectforSpringBoot</description> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <skipTests>true</skipTests> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>com.tairan.chapter</groupId> <artifactId>tairan-spring-cloud-feign-api</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>

tairan-spring-cloud-feign-logger配置

添加FeignConfig配置类,修改Feign日志输出级别,代码如下:

packagecom.tairan.chapter.feign.log.config;

importfeign.Logger; importorg.springframework.context.annotation.Bean; importorg.springframework.context.annotation.Configuration;

/**

Feign配置

该配置放到SpringBoot可以扫描到的路径下 */ @Configuration publicclassFeignConfig{

@Bean Logger.LevelfeignLevel(){ returnLogger.Level.FULL; } }

注意:该配置放到SpringBoot可以扫描到的路径下。

因为我习惯yaml配置方式,所以更改了application.properties文件为application.yml。

logging.level.=debug开启指定Feign客户端的DEBUG模式日志;

<FeignClient>为Feign客户端定义接口的完整路径

application.yml文件代码如下所示:

spring: application: name:tairan-spring-cloud-feign-logger server: port:10003 eureka: client: service-url: defaultZone:http://localhost:8761/eureka/ #defaultZone:http://litairan:litairan@localhost:8761/eureka/ #开启Feign请求压缩 feign: compression: request: enabled:true mime-types:text/xml,application/xml,application/json min-request-size:2048 response: enabled:true #DalstonSR1(待定)之后的版本默认关闭hystrix对feign的支持,如果想要使用fallback功能这里必须启用 hystrix: enabled:true logging: level: com.tairan.chapter.feign.api.HelloService:debug

入口类修改@SpringBootApplication扫描路径,可以扫描到Hystrix熔断类,即tairan-spring-cloud-feign-api中的HelloServiceHystrix类,在应用主类中通过@EnableFeignClients注解开启Feign功能,因为需要注册到服务中心,所以还需要@EnableDiscoveryClient注解,代码如下所示:

packagecom.tairan.chapter.feign.log; importorg.springframework.boot.SpringApplication; importorg.springframework.boot.autoconfigure.SpringBootApplication; importorg.springframework.cloud.client.discovery.EnableDiscoveryClient; importorg.springframework.cloud.openfeign.EnableFeignClients; @SpringBootApplication(scanBasePackages="com.tairan.chapter.feign") @EnableDiscoveryClient @EnableFeignClients("com.tairan.chapter.feign.api") publicclassTairanSpringCloudFeignLoggerApplication{ publicstaticvoidmain(String[]args){ SpringApplication.run(TairanSpringCloudFeignLoggerApplication.class,args); } }

源码位置

码云地址(本章源码):https://gitee.com/litairan/tairan-spring-cloud

本文内容总结:Feign之日志输出,Feign日志输出说明,前期准备,构建项目,tairan-spring-cloud-feign-logger配置,源码位置,

原文链接:https://www.cnblogs.com/jimoliunian/p/13885615.html