• 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:
    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以及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配置

    • 添加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可以扫描到的路径下。

    • 因为我习惯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
      # Dalston SR1(待定)之后的版本默认关闭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注解,代码如下所示:

    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);
        }
    
    }
    

    源码位置

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

    定位问题原因* 根据原因思考问题解决方案* 实践验证方案有效性* 提交验证结果
  • 相关阅读:
    Spring Boot 入门之持久层篇(三)
    Spring Boot 入门之 Web 篇(二)
    Spring Boot 入门之基础篇(一)
    Java 设计模式之建造者模式(四)
    Java 设计模式之抽象工厂模式(三)
    Java 设计模式之工厂模式(二)
    c++ type_info and typeid
    opengl& 颜色
    OpenGl And 视图
    如何写一个c++插件化系统
  • 原文地址:https://www.cnblogs.com/jimoliunian/p/13885615.html
Copyright © 2020-2023  润新知