Log4j layout日志信息格式
程序员文章站
2022-04-26 08:37:08
...
1. Log4j layout日志信息格式
1) HTMLLayout格式
2) PatternLayout格式
3) SimpleLayout格式
4) TTCCLayout格式
Log4j提供的layout有以下几种 1) org.apache.log4j.HTMLLayout(以HTML表格形式布局); 2) org.apache.log4j.PatternLayout(可以灵活地指定布局模式,重点); 3) org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串); 4) org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息);
package com.open1111; import org.apache.log4j.Logger; public class Test { private static Logger logger = Logger.getLogger(Test.class); public static void main(String[] args) { logger.fatal("严重错误fatal信息"); logger.error("报错error信息"); logger.error("报错信息", new IllegalArgumentException("非法参数")); logger.warn("警告warn信息"); logger.info("普通Info信息"); logger.debug("调试debug信息"); } }
1) HTMLLayout格式
log4j.rootLogger=DEBUG, Console #Console log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.HTMLLayout 运行结果: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Log4J Log Messages</title> <style type="text/css"> <!-- body, table {font-family: arial,sans-serif; font-size: x-small;} th {background: #336699; color: #FFFFFF; text-align: left;} --> </style> </head> <body bgcolor="#FFFFFF" topmargin="6" leftmargin="6"> <hr size="1" noshade> Log session start time Tue Dec 11 21:42:42 CST 2018<br> <br> <table cellspacing="0" cellpadding="4" border="1" bordercolor="#224466" width="100%"> <tr> <th>Time</th> <th>Thread</th> <th>Level</th> <th>Category</th> <th>Message</th> </tr> <tr> <td>0</td> <td title="main thread">main</td> <td title="Level"><font color="#993300"><strong>FATAL</strong></font></td> <td title="com.open1111.Test category">com.open1111.Test</td> <td title="Message">严重错误fatal信息</td> </tr> <tr> <td>1</td> <td title="main thread">main</td> <td title="Level"><font color="#993300"><strong>ERROR</strong></font></td> <td title="com.open1111.Test category">com.open1111.Test</td> <td title="Message">报错error信息</td> </tr> <tr> <td>2</td> <td title="main thread">main</td> <td title="Level"><font color="#993300"><strong>ERROR</strong></font></td> <td title="com.open1111.Test category">com.open1111.Test</td> <td title="Message">报错信息</td> </tr> <tr><td bgcolor="#993300" style="color:White; font-size : xx-small;" colspan="6">java.lang.IllegalArgumentException: 非法参数 <br> at com.open1111.Test.main(Test.java:8) </td></tr> <tr> <td>4</td> <td title="main thread">main</td> <td title="Level"><font color="#993300"><strong>WARN</strong></font></td> <td title="com.open1111.Test category">com.open1111.Test</td> <td title="Message">警告warn信息</td> </tr> <tr> <td>4</td> <td title="main thread">main</td> <td title="Level">INFO</td> <td title="com.open1111.Test category">com.open1111.Test</td> <td title="Message">普通Info信息</td> </tr> <tr> <td>4</td> <td title="main thread">main</td> <td title="Level"><font color="#339933">DEBUG</font></td> <td title="com.open1111.Test category">com.open1111.Test</td> <td title="Message">调试debug信息</td> </tr>
2) PatternLayout格式
有个ConversionPattern属性,灵活配置输出属性: %m 输出代码中指定的消息; %M 输出打印该条日志的方法名; %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL; %r 输出自应用启动到输出该log信息耗费的毫秒数; %c 输出所属的类目,通常就是所在类的全名; %t 输出产生该日志事件的线程名; %n 输出一个回车换行符,Windows平台为"rn”,Unix平台为"n”; %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss,SSS},输出类似:2002-10-18 22:10:28,921; %l 输出日志事件的发生位置,及在代码中的行数;
log4j.rootLogger=DEBUG, Console #Console log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n 运行结果: 2018-12-11 21:47:19,457 [main] FATAL [com.open1111.Test] - 严重错误fatal信息 2018-12-11 21:47:19,458 [main] ERROR [com.open1111.Test] - 报错error信息 2018-12-11 21:47:19,458 [main] ERROR [com.open1111.Test] - 报错信息 java.lang.IllegalArgumentException: 非法参数 at com.open1111.Test.main(Test.java:8) 2018-12-11 21:47:19,460 [main] WARN [com.open1111.Test] - 警告warn信息 2018-12-11 21:47:19,460 [main] INFO [com.open1111.Test] - 普通Info信息 2018-12-11 21:47:19,460 [main] DEBUG [com.open1111.Test] - 调试debug信息
3) SimpleLayout格式
log4j.rootLogger=DEBUG, Console #Console log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.SimpleLayout 运行结果: FATAL - 严重错误fatal信息 ERROR - 报错error信息 ERROR - 报错信息 java.lang.IllegalArgumentException: 非法参数 at com.open1111.Test.main(Test.java:8) WARN - 警告warn信息 INFO - 普通Info信息 DEBUG - 调试debug信息
4) TTCCLayout格式
log4j.rootLogger=DEBUG, Console #Console log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.TTCCLayout 运行结果: [main] FATAL com.open1111.Test - 严重错误fatal信息 [main] ERROR com.open1111.Test - 报错error信息 [main] ERROR com.open1111.Test - 报错信息 java.lang.IllegalArgumentException: 非法参数 at com.open1111.Test.main(Test.java:8) [main] WARN com.open1111.Test - 警告warn信息 [main] INFO com.open1111.Test - 普通Info信息 [main] DEBUG com.open1111.Test - 调试debug信息
下一篇: Python中暂存上传图片的方法