gpt4 book ai didi

java - 使 log4j 控制台附加程序为不同的线程使用不同的颜色

转载 作者:IT老高 更新时间:2023-10-28 20:51:23 24 4
gpt4 key购买 nike

我正在追踪一些并发问题,当登录到控制台时,让每个线程的输出行以不同的颜色显示会非常有帮助。我在 OS X 上。这可以使用转换模式来输出一些控制代码还是需要自定义附加程序来完成?有人知道怎么做吗?

2011-10-21 12:14:42,859 ["http-bio-8080"-exec-9] DEBUG ...
2011-10-21 12:14:43,198 ["http-bio-8080"-exec-10] DEBUG ...

exec-9 和 exec-10 的行应该是不同的颜色。

最佳答案

您可以使用 MulticolorLayout来自 jcabi-log .将此依赖项添加到项目中:

<dependency>
<groupId>com.jcabi</groupId>
<artifactId>jcabi-log</artifactId>
<version>0.17.1</version>
</dependency>

然后在log4j.properties中进行配置:

log4j.rootLogger=INFO, CONSOLE
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=com.jcabi.log.MulticolorLayout
log4j.appender.CONSOLE.layout.ConversionPattern=[%color{%p}] %c: %m%n

log4j.xml 中相同:

<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out" />
<layout class="com.jcabi.log.MulticolorLayout">
<param name="ConversionPattern" value="[%color{%p}] %m%n" />
</layout>
</appender>

在本例中,%p 将替换为 DEBUGINFOERROR 等,并且然后涂成与日志记录级别相关的颜色。除此之外,您还可以使用自己的颜色或预定义的颜色,例如:

log4j.appender.CONSOLE.layout.ConversionPattern=[%p] $color-cyan{%c}: %color-red{%m}%n
log4j.appender.CONSOLE.layout.ConversionPattern=[%p] $color-0;0;31{%c}: %m%n

更多关于 ANSI colors 的文档.

关于java - 使 log4j 控制台附加程序为不同的线程使用不同的颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7848325/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com