Log4j的日誌輸出級別和配置文件詳解

一,Log4j的日誌輸出級別

    Log4j由三個重要的組件構成:日誌信息的優先級,日誌信息的輸出目的地,日誌信息的輸出格式。日誌信息的優先級從高到低有ERROR、WARN、
INFO、DEBUG,分別用來指定這條日誌信息的重要程度;日誌信息的輸出目的地指定了日誌將打印到控制檯還是文件中;而輸出格式則控制了日誌信

息的顯示內容。

ALL 各級包括自定義級別 
DEBUG 指定細粒度信息事件是最有用的應用程序調試 
ERROR 錯誤事件可能仍然允許應用程序繼續運行 
FATAL 指定非常嚴重的錯誤事件,這可能導致應用程序中止 
INFO 指定能夠突出在粗粒度級別的應用程序運行情況的信息的消息 
OFF 這是最高等級,爲了關閉日誌記錄 
TRACE 指定細粒度比DEBUG更低的信息事件 
WARN 指定具有潛在危害的情況 

    級別p的級別使用q,在記錄日誌請求時,如果p>=q啓用。這條規則是log4j的核心。它假設級別是有序的。對於標準級別它們關係如下:
ALL < DEBUG < INFO < WARN < ERROR < FATAL < OFF。

驗證Log4j的規則:

public class LogClass {
   private static org.apache.log4j.Logger log = Logger
                                    .getLogger(LogClass.class);
   public static void main(String[] args) {
      log.setLevel(Level.WARN);

      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

當編譯並運行LogClass程序會產生以下結果:
Warn Message!
Error Message!
Fatal Message!

二,Log4j.properties配置文件詳解

1,log4j.rootLogger=DEBUG,console,FILE
log4j.rootLogger用來配置日誌輸出的優先級和日誌輸出的目的地。第一個字段DEBUG指定優先級,只能指定一個字段。第二個字段和第三個字段,
用來指定日誌輸出的目的地。console代表輸出到控制檯,FILE代表輸出到文件。如果只有一個輸出目的地,我們也可以只指定一個字段。

2,log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console用來配置具體的類,這裏的console就是我們在上面定義的log4j.rootLogger=DEBUG,console,FILE

3,log4j.appender.console.threshold=INFO
threshold是個全局的過濾器,把低於所設置的level的信息過濾掉,不顯示出來。

4,log4j.appender.console.layout=org.apache.log4j.PatternLayout
指定佈局樣式,Log4j具有以下幾種類型的佈局Layout
PatternLayout:根據指定的轉換模式格式化日誌輸出
HTMLLayout:格式化日誌輸出爲HTML表格
XMLLayout:格式化日誌輸出爲XML文件
SimpleLayout:以一種非常簡單的方式格式化日誌輸出
TTCCLayout:包含日誌產生的時間、線程、類別等信息

5,log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%5p] - %c -%F(%L) -%m%n
設置日誌的佈局格式

6,log4j.appender.FILE=org.apache.log4j.RollingFileAppender
輸出到文件
org.apache.log4j.ConsoleAppender(輸出日誌到控制檯)
org.apache.log4j.FileAppender(輸出日誌到文件)
org.apache.log4j.DailyRollingFileAppender(輸出日誌到文件,且每天產生一個日誌文件)
org.apache.log4j.RollingFileAppender(輸出日誌到文件,且文件大小到達指定尺寸的時候產生一個新的文件)
org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)

ConsoleAppender選項:
Threshold=WARN:指定日誌信息的最低輸出級別,默認爲DEBUG。
ImmediateFlush=true:表示所有消息都會被立即輸出,設爲false則不輸出,默認值是true。
Target=System.err:默認值是System.out。

FileAppender選項:
Threshold=WARN:指定日誌信息的最低輸出級別,默認爲DEBUG。
ImmediateFlush=true:表示所有消息都會被立即輸出,設爲false則不輸出,默認值是true。
Append=false:true表示消息增加到指定文件中,false則將消息覆蓋指定的文件內容,默認值是true。
File=D:/logs/logging.log4j:指定消息輸出到logging.log4j文件中。

DailyRollingFileAppender選項:
Threshold=WARN:指定日誌信息的最低輸出級別,默認爲DEBUG。
ImmediateFlush=true:表示所有消息都會被立即輸出,設爲false則不輸出,默認值是true。
Append=false:true表示消息增加到指定文件中,false則將消息覆蓋指定的文件內容,默認值是true。
File=D:/logs/logging.log4j:指定當前消息輸出到logging.log4j文件中。
DatePattern='.'yyyy-MM:每月滾動一次日誌文件,即每月產生一個新的日誌文件。當前月的日誌文件名爲logging.log4j,前一個月的日誌
文件名logging.log4j.yyyy-MM。
另外,也可以指定按周、天、時、分等來滾動日誌文件,對應的格式如下:
1)'.'yyyy-MM:每月
2)'.'yyyy-ww:每週
3)'.'yyyy-MM-dd:每天
4)'.'yyyy-MM-dd-a:每天兩次
5)'.'yyyy-MM-dd-HH:每小時
6)'.'yyyy-MM-dd-HH-mm:每分鐘

RollingFileAppender選項:
Threshold=WARN:指定日誌信息的最低輸出級別,默認爲DEBUG。
ImmediateFlush=true:表示所有消息都會被立即輸出,設爲false則不輸出,默認值是true。
Append=false:true表示消息增加到指定文件中,false則將消息覆蓋指定的文件內容,默認值是true。
File=D:/logs/logging.log4j:指定消息輸出到logging.log4j文件中。
MaxFileSize=100KB:後綴可以是KB, MB 或者GB。在日誌文件到達該大小時,將會自動滾動,即將原來的內容移到logging.log4j.1文件中。
MaxBackupIndex=2:指定可以產生的滾動文件的最大數,例如,設爲2則可以產生logging.log4j.1,logging.log4j.2兩個滾動文件
和一個logging.log4j文件。

7,log4j.appender.FILE.Append=true
是否追加:是

8,log4j.appender.FILE.File=../logs/log4jtest.log
日誌文件路徑

9,log4j.appender.FILE.MaxFileSize=10MB
設置文件大小超過10MB以後自動更名,將原來的日誌移動到新的新的文件中,打包備份。

10,log4j.appender.FILE.MaxBackupIndex=50
設置可以產生的滾動文件的最大數量,也就是可以產生的備份文件的最大數量。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章