log4j2日志配置颜色

1 篇文章 0 订阅
本文档详细介绍了如何在Java环境中配置Log4j2,以实现控制台输出带有颜色的日志。首先介绍了基本的日志格式配置,然后讲解了如何添加颜色高亮,最后展示了配置文件和测试代码,以ERROR、WARN、INFO、DEBUG和TRACE五个级别的日志为例,实现了不同级别日志颜色区分的效果。
摘要由CSDN通过智能技术生成

一、需求说明

相关环境说明: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

Spring Boot 配置 Log4j2 日志可以通过以下步骤实现: 1. 在 pom.xml 文件中添加 Log4j2 的依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-log4j2</artifactId> </dependency> ``` 2. 在 src/main/resources 目录下创建 log4j2.xml 文件,配置日志输出格式、级别、文件路径等信息。例如: ```xml <?xml version="1." encoding="UTF-8"?> <Configuration status="WARN"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> </Console> <RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app-%d{yyyy-MM-dd}-%i.log.gz"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> <Policies> <TimeBasedTriggeringPolicy/> <SizeBasedTriggeringPolicy size="10MB"/> </Policies> </RollingFile> </Appenders> <Loggers> <Root level="info"> <AppenderRef ref="Console"/> <AppenderRef ref="RollingFile"/> </Root> </Loggers> </Configuration> ``` 3. 在 Spring Boot 的配置文件 application.properties 或 application.yml 中添加以下配置: ```properties logging.config=classpath:log4j2.xml ``` 或 ```yaml logging: config: classpath:log4j2.xml ``` 这样就完成了 Spring Boot 配置 Log4j2 日志的过程。在代码中使用 Log4j2 日志可以直接通过注入 Logger 对象来实现,例如: ```java import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @Service public class MyService { private static final Logger logger = LogManager.getLogger(MyService.class); public void doSomething() { logger.info("doing something..."); } } ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值