一、需求说明

相关环境说明:maven 3.5.0,jdk1.8

maven依赖:

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
</dependency>
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.25</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.9.1</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-slf4j-impl</artifactId>
    <version>2.9.1</version>
</dependency>

我现在需要配置控制台打印日志,最终效果如下所示:

这里不需要使用idea的grep console插件,我们来看看怎么配置出上面的效果

比较着急看结果的可以直接看“三、相关代码”部分

 

二、实现过程

其实最主要的工作就是编写log4j2.xml文件

1. 暂且不管上面的颜色,先看看如何才能打印出以上格式的日志

通过查看官方文档https://logging.apache.org/log4j/2.x/manual/layouts.html,可以知道写成

<?xml version="1.0" encoding="UTF-8"?>
<configuration status="OFF">
    <appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d %-5level [%t] %c{1.}.%M(%L): %msg%n"/>
        </Console>
    </appenders>
    <loggers>
        <root level="trace">
            <appender-ref ref="Console"/>
        </root>
    </loggers>
</configuration>

%d表示日期,

%-5level 表示日志级别,另外在显示时占5个字符,不足的地方用空格补齐,

%t 表示线程名

%c{1.} 表示显示调用者的时候,只显示包名最后一截及方法名,前面的几段只取首字母

比如:调用logger.info的方法是com.kittycoder.Log4j2Test.test,只显示成c.k.Log4j2Test.test

%L 表示调用者所在代码的行号

%msg 表示需要打印的日志信息

%n 表示系统换行符

 

2. 现在来看看怎么把颜色给加上去

看下开头那张图,日志级别那一列颜色各不相同,线程名那一列、调用者那一列颜色都是固定的

 

先来解决日志级别那一列

看下官方给的例子,

稍微再改改,就成了

%highlight{%-5level}{ERROR=Bright RED, WARN=Bright Yellow, INFO=Bright Green, DEBUG=Bright Cyan, TRACE=Bright White}

 

然后再来解决线程名那一列、调用者那一列

稍微再改改,就成了

%style{[%t]}{bright,magenta}
%style{%c{1.}.%M(%L)}{cyan}

最终版本的pattern就是:

%d %highlight{%-5level}{ERROR=Bright RED, WARN=Bright Yellow, INFO=Bright Green, DEBUG=Bright Cyan, TRACE=Bright White} %style{[%t]}{bright,magenta} %style{%c{1.}.%M(%L)}{cyan}: %msg%n

我在控制台执行了一下,效果看着也还可以

 

三、相关代码

log4j2.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<configuration status="OFF">
    <appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <!--<PatternLayout pattern="%d %-5level [%t] %c{1.}.%M(%L): %msg%n"/>-->
            <PatternLayout pattern="%d %highlight{%-5level}{ERROR=Bright RED, WARN=Bright Yellow, INFO=Bright Green, DEBUG=Bright Cyan, TRACE=Bright White} %style{[%t]}{bright,magenta} %style{%c{1.}.%M(%L)}{cyan}: %msg%n"/>
        </Console>
    </appenders>
    <loggers>
        <root level="trace">
            <appender-ref ref="Console"/>
        </root>
    </loggers>
</configuration>

测试代码 Log4j2Test.java

package com.kittycoder;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * Created by shucheng on 2020/9/24 12:33
 */
public class Log4j2Test {

    public Logger logger = LoggerFactory.getLogger(getClass());

    @Test
    public void test() {
        logger.error("COLOR ERROR");
        logger.warn("COLOR WARN");
        logger.info("COLOR INFO");
        logger.debug("COLOR DEBUG");
        logger.trace("COLOR TRACE");
    }
}

 

参考链接:https://logging.apache.org/log4j/2.x/manual/layouts.html

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐