SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印

本文源码:GitHub·点这里 || GitEE·点这里

一、Log4j2日志简介

日志打印是了解Web项目运行的最直接方式,所以在项目开发中是需要首先搭建好的环境。

1、Log4j2特点

1)核心特点
相比与其他的日志系统,log4j2丢数据这种情况少;disruptor技术,在多线程环境下,性能高;并发的特性,减少了死锁的发生。

2)性能测试
SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印_第1张图片
SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印_第2张图片

2、日志打印之外观模式

每一种日志框架都有自己单独的API,要使用对应的框架就要使用其对应的API,增加应用程序代码和日志框架的耦合性。
《阿里巴巴Java开发手册》,其中有一条规范做了『强制』要求:
SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印_第3张图片
SLF4J
Java简易日志门面(Simple Logging Facade for Java,缩写SLF4J),是一套包装Logging 框架的界面程式,以外观模式实现。

二、配置日志打印

1、项目结构

SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印_第4张图片

2、不同环境的日志配置

使用最直接的方式,不同环境加载不同的日志配置。
1)开发环境配置

logging:
  config: classpath:log4j2-boot-dev.xml

2)生产环境配置

logging:
  config: classpath:log4j2-boot-pro.xml

3、Log4j2的配置文件




    
    
    
        
        
        
        
        
        
    

    
        
            
            
            
            
        

        
        
            
        

        
        
            
            
            
            
                
                
                
            
            
            
        

        
        
            
            
            
            
                
                
                
            
            
            
        

        
        
            
            
            
            
                
                
                
            
            
            
        
    

    
    
    
        
        
            
        
        
        
        
            
        
        
            
            
            
            
            
        
    


三、测试日志打印

1、简单的测试程序

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Log4j2Controller {
    private static final Logger LOGGER = LoggerFactory.getLogger(Log4j2Controller.class);
    /**
     * 日志级别
     * OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL
     */
    @RequestMapping("/printLog")
    public String printLog (){
        LOGGER.error("ERROR 级别日志");
        LOGGER.warn("WARN 级别日志");
        LOGGER.info("INFO 级别日志");
        LOGGER.debug("DEBUG 级别日志");
        LOGGER.trace("TRACE 级别日志");
        return "success" ;
    }
}

2、测试效果图

SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印_第5张图片

四、源代码

GitHub·地址
https://github.com/cicadasmile/spring-boot-base
GitEE·地址
https://gitee.com/cicadasmile/spring-boot-base

你可能感兴趣的:(SpringBoot2.0 基础案例(02):配置Log4j2,实现不同环境日志打印)