log4j2日志配置颜色

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 表示系统换行符

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

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

看下官方给的例子
在这里插入图片描述
稍微再改改,就成了

%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>
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

凌兮~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值