Log4j 2配置与IntelliJ IDEA控制台颜色

Posted 富的只剩下代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Log4j 2配置与IntelliJ IDEA控制台颜色相关的知识,希望对你有一定的参考价值。

原文地址:http://www.hankcs.com/program/java/log4j-2-console-color-configuration-with-intellij-idea.html

准备开一大项目的话,日志系统必不可少。Log4j是Java平台上最好的日志组件了,Log4j 2升级了不少API,拓展性更好。

Log4j 2安装

需要两个Jar即可:log4j-api-2.0-rc1.jar和log4j-core-2.0-rc1。像我这样的强迫症患者还得捎上doc和sources才行。

最简单的一个测试


  
  1. import org.apache.logging.log4j.LogManager;
  2. import org.apache.logging.log4j.Logger;
  3.  
  4. public class HelloWorld 
  5.     private static Logger logger = LogManager.getLogger("HelloWorld");
  6.     public static void main(String[] args) 
  7.         logger.debug("Will not show.");
  8.         logger.error("Hello, World!");
  9.     

即可在控制台看到


  
  1. 20:35:34.712 [main] ERROR com.hankcs.Main - Hello, World!

配置文件log4j2.xml

默认的配置只将ERROR及以上级别的日志输出到控制台,可以通过在根目录建立一个log4j2.xml来自定义它:


  
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration status="OFF">
  3.     <appenders>
  4.         <Console name="Console" target="SYSTEM_OUT">
  5.             <PatternLayout pattern="%dHH:mm:ss.SSS [%t] %-5level %logger36 - %msg%n"/>
  6.         </Console>
  7.     </appenders>
  8.     <loggers>
  9.         <root level="trace">
  10.             <appender-ref ref="Console"/>
  11.         </root>
  12.     </loggers>
  13. </configuration>

然后来一段复杂一点的测试:


  
  1. package com.hankcs;
  2.  
  3. import org.apache.logging.log4j.Level;
  4. import org.apache.logging.log4j.LogManager;
  5.  
  6. public class Main
  7.     public static org.apache.logging.log4j.Logger logger = LogManager.getLogger();
  8.     public static void main(String[] args)
  9.     
  10.         add(1, 2);
  11.     
  12.  
  13.     public static int add(int a , int b)
  14.     
  15.         logger.entry(a, b);
  16.         logger.info("我是info信息");
  17.         logger.warn("我是warn信息");
  18.         logger.error("我是error信息");
  19.         logger.fatal("我是fatal信息");
  20.         logger.printf(Level.TRACE, "%d+%d=%d", a, b, a + b);
  21.         logger.exit(+ b);
  22.         return a + b;
  23.     

输出:


  
  1. 20:39:35.937 [main] TRACE com.hankcs.Main - entry params(1, 2)
  2. 20:39:35.938 [main] INFO  com.hankcs.Main - 我是info信息
  3. 20:39:35.938 [main] WARN  com.hankcs.Main - 我是warn信息
  4. 20:39:35.938 [main] ERROR com.hankcs.Main - 我是error信息
  5. 20:39:35.938 [main] FATAL com.hankcs.Main - 我是fatal信息
  6. 20:39:35.939 [main] TRACE com.hankcs.Main - 1+2=3
  7. 20:39:35.939 [main] TRACE com.hankcs.Main - exit with(3)

真优雅!

Log4j 2自定义配色

如果是eclipse的话,大概还能在控制台显示出不同的颜色吧,可惜IntelliJ IDEA的控制台不支持ASCII颜色。但是可以通过一个控制台配色插件Grep Console来实现,安装后更改配置为:

然后修改配置文件log4j2.xml为:

 
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration status="OFF">
  3.     <appenders>
  4.         <Console name="Console" target="SYSTEM_OUT">
  5.             <PatternLayout pattern="%highlight%dHH:mm:ss.SSS %-5level %logger36.%M() @%L - %msg%nFATAL=Bright Red, ERROR=Bright Magenta, WARN=Bright Yellow, INFO=Bright Green, DEBUG=Bright Cyan, TRACE=Bright White"/>
  6.         </Console>
  7.     </appenders>
  8.     <loggers>
  9.         <root level="trace">
  10.             <appender-ref ref="Console"/>
  11.         </root>
  12.     </loggers>
  13. </configuration>

运行效果很美观:

这里我为每种颜色都加了Bright属性,不然的话字体不一样会很难受的。自定义颜色请参考http://logging.apache.org/log4j/2.x/manual/layouts.html


以上是关于Log4j 2配置与IntelliJ IDEA控制台颜色的主要内容,如果未能解决你的问题,请参考以下文章

解决IntelliJ IDEA控制台乱码问题[包含程序运行时的log4j日志以及tomcat日志乱码]

解决IntelliJ IDEA控制台乱码问题[包含程序运行时的log4j日志以及tomcat日志乱码]

intellij idea 17 log4j 中文乱码

IntelliJ IDEA里面怎么配置SVN

intellij idea svn怎么比较

Intellij idea操作maven时控制台中文乱码