網上很流行的Log4j設定檔,其中開始的一段是這樣的
log4j.rootLogger=DEBUG,CONSOLE,A1,im
log4j.addivity.org.apache=true # 應用於控制台 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.Threshold=DEBUG log4j.appender.CONSOLE.Target=System.out log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5 %x - %m%n #log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRI TY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n log4j.addivity.org.apache=true
log4j.addivity.org.apache=true 無論是true/false,你會發現日誌輸出結果沒有任何變化。
正確的格式應該是:
log4j.additivity.org.apache=true
additivity的作用在於 children-logger是否使用 rootLogger的配置,例如 輸出終端。
樣本如下:
java代碼
public static void main(String[] args) { for(int i = 0 ;i < 1000;i ++) logger.debug("RollingFileAppenderTest:" + i); }
log4j.perperties
log4j.rootLogger=debug,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %5p %t %c%M %l-%m%n
log4j.logger.log4jdemo.RollingFileAppenderDemo=debug,rollinglogfile
log4j.additivity.log4jdemo.RollingFileAppenderDemo=false
log4j.appender.rollinglogfile=org.apache.log4j.RollingFileAppender
log4j.appender.rollinglogfile.Append=true
log4j.appender.rollinglogfile.File=rollinglogfile.log
log4j.appender.rollinglogfile.MaxFileSize=200kb
log4j.appender.rollinglogfile.MaxBackupIndex=10
log4j.appender.rollinglogfile.layout=org.apache.log4j.TTCCLayout
如果additivity為false,那麼只產生一個rollinglogfile.log的記錄檔,螢幕上沒有日誌資訊輸出。如果additivity為true那麼,螢幕上有日誌資訊顯示(因為rootLogger 的日誌輸出終端為stdout-螢幕),而且會產生rollinglogfile.log的記錄檔。
additivity在log4j預設為true。這解釋了為什麼有些時候,一個日誌資訊在螢幕上會有多次輸出。