1. 設定檔
Log4J設定檔的基本格式如下:
複製代碼代碼如下:
#配置根Logger
log4j.rootLogger = [ level ] , appenderName1 , appenderName2 , …
#配置日誌資訊輸出目的地Appender
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
…
log4j.appender.appenderName.optionN = valueN
#配置日誌資訊的格式(佈局)
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
…
log4j.appender.appenderName.layout.optionN = valueN
其中[level] 是日誌輸出級別,共有5級:
複製代碼代碼如下:
FATAL 0
ERROR 3
WARN 4
INFO 6
DEBUG 7
Appender 為日誌輸出目的地,Log4j提供的appender有以下幾種:
複製代碼代碼如下:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(檔案),
org.apache.log4j.DailyRollingFileAppender(每天產生一個日誌檔案),
org.apache.log4j.RollingFileAppender(檔案大小到達指定尺寸的時候產生一個新的檔案),
org.apache.log4j.WriterAppender(將日誌資訊以串流格式傳送到任意指定的地方)
Layout:日誌輸出格式,Log4j提供的layout有以下幾種:
org.apache.log4j.HTMLLayout(以HTML表格形式佈局),
org.apache.log4j.PatternLayout(可以靈活地指定佈局模式),
org.apache.log4j.SimpleLayout(包含日誌資訊的層級和資訊字串),
org.apache.log4j.TTCCLayout(包含日誌產生的時間、執行緒、類別等等資訊)
列印參數: Log4J採用類似C語言中的printf函數的列印格式格式化日誌訊息,如下:
複製代碼代碼如下:
%m 輸出代碼中指定的訊息%p 輸出優先權,即DEBUG,INFO,WARN,ERROR,FATAL
%r 輸出自應用程式啟動到輸出該log資訊耗費的毫秒數%c 輸出所屬的類別目,通常就是所在類別的全名%t 輸出產生該日誌事件的執行緒名稱%n 輸出一個回車換行符,Windows平台為“/r/n”,Unix平台為“/n”
%d 輸出日誌時間點的日期或時間,預設格式為ISO8601,也可以在其後指定格式,例如:%d{yyy MMM dd HH:mm:ss , SSS},輸出類似:2002年10月18日22 : 10 : 28 , 921
%l 輸出日誌事件的發生位置,包括類別目名、發生的線程,以及在程式碼中的行數。範例:Testlog4.main(TestLog4.java: 10 )
2. 在程式碼中初始化Logger: 1)在程式中呼叫BasicConfigurator.configure()方法:為根記錄器增加一個ConsoleAppender,輸出格式透過PatternLayout設為"%-4r [%t] %-5p %c %x - %m%n",還有根記錄器的預設等級是Level.DEBUG.
2)配置放在檔案裡,透過命令列參數傳遞檔案名字,透過PropertyConfigurator.configure(args[x])解析並配置;
3)配置放在文件裡,透過環境變數傳遞檔名等訊息,利用log4j預設的初始化過程解析並配置;
4)配置放在文件裡,透過應用程式伺服器設定傳遞檔案名稱等訊息,利用一個特殊的servlet來完成設定。
3. 為不同的Appender 設定日誌輸出等級:
當偵錯系統時,我們往往注意的只是異常等級的日誌輸出,但是通常所有層級的輸出都是放在一個檔案裡的,如果日誌輸出的層級是BUG! ?那就慢慢去找吧。
這時我們或許會想要是能把異常訊息單獨輸出到一個檔案裡該有多好。當然可以,Log4j已經提供了這樣的功能,我們只需要在配置中修改Appender的Threshold 就能實現,比如下面的例子:
[設定檔]
複製代碼代碼如下:
### set log levels ###
log4j.rootLogger = debug , stdout , D , E
### 輸出到控制台###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n
### 輸出到日誌檔###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG ## 輸出DEBUG等級以上的日誌
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
### 保存異常訊息到單獨檔案###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/error.log ## 異常日誌檔名
log4j.appender.D.Append = true
log4j.appender.D.Threshold = ERROR ## 只輸出ERROR等級以上的日誌!!!
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
[程式碼中使用]
public class TestLog4j {
public static void main(String[] args) {
PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " );
Logger logger = Logger.getLogger(TestLog4j. class );
logger.debug( " debug " );
logger.error( " error " );
}
}
運行一下,看看異常訊息是不是保存在了一個單獨的檔案error.log中