SpringCloud组件:Feign之日志输出

Feign之日志输出

在我们日常开发过程中,经常会查看日志解决问题,那么Feign是不是也有日志输出呢?
答案:是的。
在构建@FeignClient注解修饰的服务客户端时,会为每一个客户端都创建一个Feign.Logger实例,可以利用该日志对象的Debug模式来分析Feign的请求细节。

环境配置如下:

  • SpringBoot:2.1.1.RELEASE
  • SpringCloud:Greenwich.RC1
  • Java:1.8
  • Maven:3.5.2

Feign日志输出说明

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

日志级别枚举类Logger.Level

  1. NONE:不输出日志
  2. BASIC:输出请求方法、URL、响应状态码、执行时间
  3. HEADERS:基本信息以及请求和响应头
  4. FULL:请求和响应的headsbodymetadata,建议使用这个级别

前期准备

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

注意:2、3步骤tairan-spring-cloud-feign-apitairan-spring-cloud-feign-privder项目借用SpringCloud组件:创建第一个Feign客户端文章中创建的项目。

构建项目

同样的是采用idea开发工具创建一个SpringBoot项目,在依赖选择界面对应的添加WebFeign以及Eureka Discovery依赖,直接完成创建项目。
项目的pom.xml内容如下所示:

......//省略部分
<artifactId>tairan-spring-cloud-feign-logger</artifactId>
<name>tairan-spring-cloud-feign-logger</name>
<description>Demo project for Spring Boot</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配置

  1. 添加FeignConfig配置类,修改Feign日志输出级别,代码如下:
package com.tairan.chapter.feign.log.config;

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

/**
 * Feign配置
 * 该配置放到SpringBoot可以扫描到的路径下
 */
@Configuration
public class FeignConfig {

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

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

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

logging.level.<FeignClient>=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
  # Dalston SR1(待定)之后的版本默认关闭hystrix对feign的支持,如果想要使用fallback功能这里必须启用
  hystrix:
    enabled: true
logging:
  level:
    com.tairan.chapter.feign.api.HelloService: debug
  1. 入口类修改@SpringBootApplication扫描路径,可以扫描到Hystrix熔断类,即tairan-spring-cloud-feign-api中的HelloServiceHystrix类,在应用主类中通过@EnableFeignClients注解开启Feign功能,因为需要注册到服务中心,所以还需要@EnableDiscoveryClient注解,代码如下所示:
package com.tairan.chapter.feign.log;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

@SpringBootApplication(scanBasePackages = "com.tairan.chapter.feign")
@EnableDiscoveryClient
@EnableFeignClients("com.tairan.chapter.feign.api")
public class TairanSpringCloudFeignLoggerApplication {

    public static void main(String[] args) {
        SpringApplication.run(TairanSpringCloudFeignLoggerApplication.class, args);
    }

}

运行测试

  1. 启动服务注册中心tairan-spring-cloud-eureka
  2. 启动服务提供方tairan-spring-cloud-feign-provider
  3. 启动服务消费方tairan-spring-cloud-feign-logger
  4. 访问tairan-spring-cloud-feign-logger工程的/feign-hello接口,链接:http://localhost:10003/feign-hello,查看idea控制台打印结果
  5. 关闭服务提供方tairan-spring-cloud-feign-provider
  6. 访问tairan-spring-cloud-feign-logger工程的/feign-hello接口,链接:http://localhost:10003/feign-hello,查看idea控制台打印结果

执行4操作后,访问链接http://localhost:10003/feign-hello后,idea控制台打印结果如下所示:

2019-03-01 19:46:17.191 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] ---> GET http://tairan-spring-cloud-feign-provider/hello HTTP/1.1
2019-03-01 19:46:17.191 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] Accept-Encoding: gzip
2019-03-01 19:46:17.191 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] Accept-Encoding: deflate
2019-03-01 19:46:17.191 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] ---> END HTTP (0-byte body)
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] <--- HTTP/1.1 200 (5ms)
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] cache-control: no-cache, no-store, max-age=0, must-revalidate
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] content-length: 40
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] content-type: text/plain;charset=UTF-8
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] date: Fri, 01 Mar 2019 11:46:17 GMT
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] expires: 0
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] pragma: no-cache
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] x-content-type-options: nosniff
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] x-frame-options: DENY
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] x-xss-protection: 1; mode=block
2019-03-01 19:46:17.197 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] 
2019-03-01 19:46:17.198 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] tairan-spring-cloud-feign-provider:10001
2019-03-01 19:46:17.198 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] <--- END HTTP (40-byte body)

执行5操作后,访问链接http://localhost:10003/feign-hello后,idea控制台打印结果如下所示:

2019-03-01 19:47:27.782 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] ---> GET http://tairan-spring-cloud-feign-provider/hello HTTP/1.1
2019-03-01 19:47:27.782 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] Accept-Encoding: gzip
2019-03-01 19:47:27.782 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] Accept-Encoding: deflate
2019-03-01 19:47:27.782 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] ---> END HTTP (0-byte body)
2019-03-01 19:47:27.791 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] <--- ERROR ConnectException: Connection refused (Connection refused) (8ms)
2019-03-01 19:47:27.792 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] java.net.ConnectException: Connection refused (Connection refused)
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
    ……

2019-03-01 19:47:27.792 DEBUG 6643 --- [ign-provider-10] c.tairan.chapter.feign.api.HelloService  : [HelloService#getMessage] <--- END ERROR

如上所示,Feign的日志输出级别修改成功。

源码位置

本章源码已经上传到淡若悠然,请结合源码进行学习,感谢阅读。

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,204评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,091评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,548评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,657评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,689评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,554评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,302评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,216评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,661评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,851评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,977评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,697评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,306评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,898评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,019评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,138评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,927评论 2 355

推荐阅读更多精彩内容