【J2EE系列】log4j日誌輸出分級別或模塊到不一樣文件

  1、  實現分模塊,輸出到不一樣的日誌文件,   如下是log4j.properties的實現   
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender   
  log4j.appender.file.file=src\\log\\all.log   
  log4j.appender.file.DatePattern='.'yyyy-MM-dd   
  log4j.appender.file.layout=org.apache.log4j.PatternLayout   
  log4j.appender.file.layout.ConversionPattern=[%-5p]   %d{yyyy-MM-dd   HH:mm:ss,SSS}  method:%l%n%m%n   
  log4j.rootLogger=debug,file    
    
  log4j.appender.usermanagerfile=org.apache.log4j.DailyRollingFileAppender   
  log4j.appender.usermanagerfile.file=src\\log\\usermanager.log   
  log4j.appender.usermanagerfile.DatePattern='.'yyyy-MM-dd   
  log4j.appender.usermanagerfile.layout=org.apache.log4j.PatternLayout   
  log4j.appender.usermanagerfile.layout.ConversionPattern=[%-5p]   %d{yyyy-MM-dd   HH:mm:ss,SSS}   method:%l%n%m%n   
  log4j.logger.userManager   =   info,   usermanagerfile

 調用方式
public   static   void   main(String[]   args)throws   Exception   {   
      
    Log   logger   =   LogFactory.getLog("file");   
    Log   logger   =   LogFactory.getLog("usermanager");   
    
  }


 2、 log4j日誌分級別輸出到不一樣文件
 
  配置文件 
#log4j.rootLogger=info,stdoutdebug,error 
log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n 

log4j.logger.info=info 
log4j.appender.info=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.info.layout=org.apache.log4j.PatternLayout 
log4j.appender.info.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n 
log4j.appender.info.datePattern='.'yyyy-MM-dd 
log4j.appender.info.Threshold = INFO 
log4j.appender.info.append=true 
log4j.appender.info.File=${catalina.home}/logs/log4j/info.log 

log4j.logger.debug=debug 
log4j.appender.debug=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.debug.layout=org.apache.log4j.PatternLayout 
log4j.appender.debug.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n 
log4j.appender.debug.datePattern='.'yyyy-MM-dd 
log4j.appender.debug.Threshold = DEBUG 
log4j.appender.debug.append=true 
log4j.appender.debug.File=${catalina.home}/logs/log4j/debug.log 

log4j.logger.warn=warn 
log4j.appender.warn=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.warn.layout=org.apache.log4j.PatternLayout 
log4j.appender.warn.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n 
log4j.appender.warn.datePattern='.'yyyy-MM-dd 
log4j.appender.warn.Threshold = DEBUG 
log4j.appender.warn.append=true 
log4j.appender.warn.File=${catalina.home}/logs/log4j/warn.log 

log4j.logger.error=error 
log4j.appender.error=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.error.layout=org.apache.log4j.PatternLayout 
log4j.appender.error.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n 
log4j.appender.error.datePattern='.'yyyy-MM-dd 
log4j.appender.error.Threshold = ERROR 
log4j.appender.error.append=true 
log4j.appender.error.File=$${catalina.home}/logs/log4j/error.log

ConversionPattern設置輸出格式的參數說明: 
%p: 輸出日誌信息優先級,即DEBUG,INFO,WARN,ERROR,FATAL, 
%d: 輸出日誌時間點的日期或時間,默認格式爲ISO8601,也能夠在其後指定格式,好比:%d{yyy MMM dd HH:mm:ss,SSS},輸出相似:2011年08月30日 15:00:00,921 
%r: 輸出自應用啓動到輸出該log信息耗費的毫秒數 
%c: 輸出日誌信息所屬的類目,一般就是所在類的全名 
%t: 輸出產生該日誌事件的線程名 
%l: 輸出日誌事件的發生位置,至關於%C.%M(%F:%L)的組合,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(TestLog4.java:10) 
%x: 輸出和當前線程相關聯的NDC(嵌套診斷環境),尤爲用到像java servlets這樣的多客戶多線程的應用中。 
%%: 輸出一個」%」字符 
%F: 輸出日誌消息產生時所在的文件名稱 
%L: 輸出代碼中的行號 
%m: 輸出代碼中指定的消息,產生的日誌具體信息 
%n: 輸出一個回車換行符,Windows平臺爲」\r\n」,Unix平臺爲」\n」輸出日誌信息換行 
能夠在%與模式字符之間加上修飾符來控制其最小寬度、最大寬度、和文本的對齊方式。如: 
1)%20c:指定輸出category的名稱,最小的寬度是20,若是category的名稱小於20的話,默認的狀況下右對齊。 
2)%-20c:指定輸出category的名稱,最小的寬度是20,若是category的名稱小於20的話,」-」號指定左對齊。 
3)%.30c:指定輸出category的名稱,最大的寬度是30,若是category的名稱大於30的話,就會將左邊多出的字符截掉,但小於30的話也不會有空格。 
4)%20.30c:若是category的名稱小於20就補空格,而且右對齊,若是其名稱長於30字符,就從左邊交遠銷出的字符截掉。



程序中使用: 
在程序中使用Log4j以前,首先要將commons-logging.jar和logging-log4j-1.2.9.jar導入到classpath中,並將log4j.properties放於src根目錄中。 
在這裏推薦使用commons-logging結合log4j進行日誌記錄 <!--EndFragment--> 
相關文章
相關標籤/搜索