log4j日誌分模塊打印,同時不打印到控制檯上

   因爲定時刷新程序的啓用,致使catalina.out配置文件中打入大量日誌,導致程序調試困難。沒法正常查看日誌。因此客戶要求將性能流量配置日誌遷移出catalina.out目錄。修改log4j配置文件後,發現分文件中有了日誌輸出,可是,catalina.out文件中依然有性能流量日誌輸出。 java

原始配置方法以下:
log4j.logger.com.test.cao.snmpgather = INFO, snmpgather

log4j.appender.snmpgather=org.apache.log4j.DailyRollingFileAppender

log4j.appender.snmpgather.File=${catalina.home}/logs/performance/snmpgather_

log4j.appender.snmpgather.DatePattern= yyyy-MM- dd'.log'

log4j.appender.snmpgather.layout=org.apache.log4j.PatternLayout

log4j.appender.snmpgather.layout.ConversionPattern= %-d{yyyy -MM-dd HH:mm:ss,SSS} [%p] [%C.%M:%L] %m%n
後來發現了以下方法,則可將日誌從catalina.out工做臺日志文件中移出,

log4j.additivity apache


現配置文件以下:       
log4j.logger.com.test.cao.snmpgather = INFO, snmpgather

log4j.appender.snmpgather=org.apache.log4j.DailyRollingFileAppender

log4j.appender.snmpgather.File=${catalina.home}/logs/performance/snmpgather_

log4j.appender.snmpgather.DatePattern= yyyy-MM- dd'.log'

log4j.appender.snmpgather.layout=org.apache.log4j.PatternLayout

log4j.appender.snmpgather.layout.ConversionPattern= %-d{yyyy -MM-dd HH:mm:ss,SSS} [%p] [%C.%M:%L] %m%n
 
log4j.additivity.com.linkage.module.liposs.system.cao.snmpgather = false
 
下面是log4j.additivity解釋:
log4j.additivity是 子Logger 是否繼承 父Logger 的 輸出源(appender) 的標誌位。
具體說,默認狀況下 子Logger 會繼承 父Logger 的appender,也就是說 子Logger 會在 父Logger 的appender裏輸出。
如果additivity設爲false,則 子Logger 只會在本身的appender裏輸出,而不會在 父Logger 的appender裏輸出。
          
因爲父log爲:       
log4j.rootCategory=, A1 , R

log4j.appender.A1=org.apache.log4j.ConsoleAppender

log4j.appender.A1.Threshold=INFO

log4j.appender.A1.layout=org.apache.log4j.PatternLayout

log4j.appender.A1.layout.ConversionPattern= %-d{yyyy -MM-dd HH:mm:ss} [%c]-[%p] %m%n

log4j.appender.R.Threshold=INFO

log4j.appender.R.MaxFileSize=100KB

log4j.appender.R.MaxBackupIndex=10

log4j.appender.R.layout=org.apache.log4j.PatternLayout

log4j.appender.R.layout.ConversionPattern= %p %t %c - %m%n
 
因此會打到工做臺中。
將additivity設爲false則只依賴與自身的配置。
相關文章
相關標籤/搜索