Log4j输出格式控制--log4j的PatternLayout参数含义
生活随笔
收集整理的這篇文章主要介紹了
Log4j输出格式控制--log4j的PatternLayout参数含义
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
做項目被log4j的輸出格式化參數(shù)搞煩了,索性把API的相關(guān)部分大致翻譯一下,原文參見http://logging.apache.org/log4j/docs/api/org/apache/log4j/PatternLayout.html
?
?
| %c | 列出logger名字空間的全稱,如果加上{<層數(shù)>}表示列出從最內(nèi)層算起的指定層數(shù)的名字空間 | log4j配置文件參數(shù)舉例 | 輸出顯示媒介 |
| 假設(shè)當前l(fā)ogger名字空間是"a.b.c" | |||
| %c | a.b.c | ||
| %c{2} | b.c | ||
| %20c | (若名字空間長度小于20,則左邊用空格填充) | ||
| %-20c | (若名字空間長度小于20,則右邊用空格填充) | ||
| %.30c | (若名字空間長度超過30,截去多余字符) | ||
| %20.30c | (若名字空間長度小于20,則左邊用空格填充;若名字空間長度超過30,截去多余字符) | ||
| %-20.30c | (若名字空間長度小于20,則右邊用空格填充;若名字空間長度超過30,截去多余字符) | ||
| %C | 列出調(diào)用logger的類的全名(包含包路徑) | 假設(shè)當前類是"org.apache.xyz.SomeClass" | |
| %C | org.apache.xyz.SomeClass | ||
| %C{1} | SomeClass | ||
| %d | 顯示日志記錄時間,{<日期格式>}使用ISO8601定義的日期格式 | %d{yyyy/MM/dd HH:mm:ss,SSS} | 2005/10/12 22:23:30,117 |
| %d{ABSOLUTE} | 22:23:30,117 | ||
| %d{DATE} | 12 Oct 2005 22:23:30,117 | ||
| %d{ISO8601} | 2005-10-12 22:23:30,117 | ||
| %F | 顯示調(diào)用logger的源文件名 | %F | MyClass.java |
| %l | 輸出日志事件的發(fā)生位置,包括類目名、發(fā)生的線程,以及在代碼中的行數(shù) | %l | MyClass.main(MyClass.java:129) |
| %L | 顯示調(diào)用logger的代碼行 | %L | 129 |
| %m | 顯示輸出消息 | %m | This is a message for debug. |
| %M | 顯示調(diào)用logger的方法名 | %M | main |
| %n | 當前平臺下的換行符 | %n | Windows平臺下表示rn UNIX平臺下表示n |
| %p | 顯示該條日志的優(yōu)先級 | %p | INFO |
| %r | 顯示從程序啟動時到記錄該條日志時已經(jīng)經(jīng)過的毫秒數(shù) | %r | 1215 |
| %t | 輸出產(chǎn)生該日志事件的線程名 | %t | MyClass |
| %x | 按NDC(Nested Diagnostic Context,線程堆棧)順序輸出日志 | 假設(shè)某程序調(diào)用順序是MyApp調(diào)用com.foo.Bar | |
| %c %x - %m%n | MyApp - Call com.foo.Bar. com.foo.Bar - Log in Bar MyApp - Return to MyApp. | ||
| %X | 按MDC(Mapped Diagnostic Context,線程映射表)輸出日志。通常用于多個客戶端連接同一臺服務器,方便服務器區(qū)分是那個客戶端訪問留下來的日志。 | %X{5} | (記錄代號為5的客戶端的日志) |
| %% | 顯示一個百分號 | %% | % |
?
列了這么多,舉幾個實際的例子吧,比如log4j.properties的內(nèi)容為:
| #log4j config log4j.rootLogger=DEBUG,OUTPUT log4j.appender.OUTPUT.layout=org.apache.log4j.PatternLayout log4j.appender.OUTPUT.layout.ConversionPattern=%d{DATE} %-4r [%t] %-5p %c %x - %m%n …… |
?
那么一個可能的輸出是:
12 Oct 2005 22:23:30,117 0 [main] INFO MyApp - Entering application.
……
12 Oct 2005 22:23:30,162 45 [main] INFO MyApp - Exiting application.
from:http://blog.gceclub.sun.com.cn/index.php?op=ViewArticle&articleId=734&blogId=6
https://blog.csdn.net/guoquanyou/article/details/5689652
《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的Log4j输出格式控制--log4j的PatternLayout参数含义的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Logger PatternLayout
- 下一篇: Log4j详细介绍(七)----日志格式