log4j additivity 作用

來源:互聯網
上載者:User

網上很流行的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。這解釋了為什麼有些時候,一個日誌資訊在螢幕上會有多次輸出。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.