Log4j輸出格式控制--log4j的PatternLayout引數含義
阿新 • • 發佈:2018-12-14
引數 | 說明 | 例子 | |
---|---|---|---|
%c |
列出logger名字空間的全稱,如果加上{<層數>}表示列出從最內層算起的指定層數的名字空間 |
log4j配置檔案引數舉例 |
輸出顯示媒介 |
假設當前logger名字空間是"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 |
列出呼叫logger的類的全名(包含包路徑) | 假設當前類是"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 |
顯示呼叫logger的原始檔名 | %F | MyClass.java |
%l |
輸出日誌事件的發生位置,包括類目名、發生的執行緒,以及在程式碼中的行數 | %l | MyClass.main(MyClass.java:129) |
%L |
顯示呼叫logger的程式碼行 | %L | 129 |
%m |
顯示輸出訊息 | %m | This is a message for debug. |
%M |
顯示呼叫logger的方法名 | %M | main |
%n |
當前平臺下的換行符 | %n | Windows平臺下表示rn UNIX平臺下表示n |
%p |
顯示該條日誌的優先順序 | %p | INFO |
%r |
顯示從程式啟動時到記錄該條日誌時已經經過的毫秒數 | %r | 1215 |
%t |
輸出產生該日誌事件的執行緒名 | %t | MyClass |
%x |
按NDC(Nested Diagnostic Context,執行緒堆疊)順序輸出日誌 | 假設某程式呼叫順序是MyApp呼叫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,執行緒對映表)輸出日誌。通常用於多個客戶端連線同一臺伺服器,方便伺服器區分是那個客戶端訪問留下來的日誌。 | %X{5} | (記錄代號為5的客戶端的日誌) |
%% |
顯示一個百分號 | %% | % |
列了這麼多,舉幾個實際的例子吧,比如log4j.properties的內容為:
#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.