首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使log4j控制台附加器对不同的线程使用不同的颜色

使log4j控制台附加器对不同的线程使用不同的颜色
EN

Stack Overflow用户
提问于 2011-10-21 18:45:42
回答 3查看 64.4K关注 0票数 46

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

代码语言:javascript
复制
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的行应使用不同的颜色。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-10-21 18:59:04

您可以扩展PatternLayout并覆盖format(ILoggingEvent)。在这里,你可以查看LoggingEvent.getThreadName(),根据线程名(奇数/偶数,也许?)获得一些颜色。

为了将颜色输出到控制台,您需要使用ANSI Escape Sequence

例如,要输出红色文本:

代码语言:javascript
复制
  "\u001b["  // Prefix - see [1]
+ "0"        // Brightness
+ ";"        // Separator
+ "31"       // Red foreground
+ "m"        // Suffix
+ text       // the text to output
+ "\u001b[m " // Prefix + Suffix to reset color

下面是一些例子:

由Ingo Thon.

  • Colour-coded Console Logging with Log4J博客发布的
  • ColoredPatternLayout实现。

另外,也许你也可以通过在MDC中设置一个带有随机ANSI颜色代码的变量"randColor“来实现这一点,例如,在Filter中,并在log4j的控制台附加器配置中的标准org.apache.log4j.PatternLayoutconversionPattern中使用它:

代码语言:javascript
复制
<appender name="consoleAppender" class="org.apache.log4j.ConsoleAppender">
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern"
               value="\u001b[0;%X{randColor}m ....... \u001b[m" />
    </layout>
</appender>

1什么是"\u001BJ" represent?

票数 30
EN

Stack Overflow用户

发布于 2012-08-30 23:01:54

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

代码语言:javascript
复制
<dependency>
  <groupId>com.jcabi</groupId>
  <artifactId>jcabi-log</artifactId>
  <version>0.17.1</version>
</dependency>

然后在log4j.properties中进行配置

代码语言:javascript
复制
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中也是如此

代码语言:javascript
复制
<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等替换,然后绘制为与日志记录级别相关的颜色。此外,您还可以使用自己的颜色或预定义的颜色,例如:

代码语言:javascript
复制
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的更多文档。

票数 49
EN

Stack Overflow用户

发布于 2021-10-20 14:20:09

请参见PatternLayout,配置属性"highlight":https://logging.apache.org/log4j/2.x/manual/layouts.html#PatternLayout

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7848325

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档