LOG4J 入門

爲什麼Tomcat下面會生成TXT日誌?

 

 

認識LOG4J

 

Apache開放源代碼  控制檯 文件 控制輸出格式  日誌生成過程  配置文件配置

 

 

LOG4J配置步驟

 

1:加入JAR

2CLASSPATH下建立log4j.properties

3:根據自己需要,修改log4j.properties屬性配置

4:代碼中控制日誌生成

 

LOG4J基本配置

log4j.rootLogger=OFF

log4j.rootLogger=error,R

#log4j.category.com.layer=warn,A1,R

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

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

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

log4j.appender.R=org.apache.log4j.DailyRollingFileAppender

#log4j.appender.R.File=D:/log/log.txt

log4j.appender.R.File=../logs/error.log

#log4j.appender.R.MaxFileSize=500KB

#log4j.appender.R.MaxBackupIndex=1

#log4j.appender.R.layout=org.apache.log4j.HTMLLayout

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

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

 

 

 

 

 

 

 

 

 

 

 

 

log4j.rootLogger=error,R

OFF 是日誌記錄的優先級,分爲OFFFATALERRORWARNINFODEBUGALL或者自定義的級別。Log4j建議只使用四個級別,優先級從高到低分別是ERRORWARNINFODEBUG。比如在這裏定義了INFO級別,只有等於及高於這個級別的才進行處理,則應用程序中所有DEBUG級別的日誌信息將不被打印出來。ALL:打印所有的日誌,OFF:關閉所有的日誌輸出。

 

 

log4j.appender.R=org.apache.log4j.DailyRollingFileAppender

配置日誌信息輸出目的地 Appender

org.apache.log4j.ConsoleAppender(控制檯),

org.apache.log4j.FileAppender(文件),

org.apache.log4j.DailyRollingFileAppender(每天產生一個日誌文件),

org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件)

可通過log4j.appender.R.MaxFileSize=100KB設置文件大小,還可通過log4j.appender.R.MaxBackupIndex=1設置爲保存一個備份文件

 

 

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

配置日誌信息的格式(佈局)Layout

org.apache.log4j.HTMLLayout(以HTML表格形式佈局),

org.apache.log4j.PatternLayout(可以靈活地指定佈局模式),

org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),

org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)

 

 

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

格式化日誌信息

  Log4J採用類似C語言中的printf函數的打印格式格式化日誌信息,打印參數如下:

  %m 輸出代碼中指定的消息

  %p 輸出優先級,即DEBUGINFOWARNERRORFATAL

  %r 輸出自應用啓動到輸出該log信息耗費的毫秒數

  %c 輸出所屬的類目,通常就是所在類的全名

  %t 輸出產生該日誌事件的線程名

  %n 輸出一個回車換行符,Windows平臺爲“rn”Unix平臺爲“n”

  %d 輸出日誌時間點的日期或時間,默認格式爲ISO8601,也可以在其後指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},輸出類似:20021018 221028921

%l 輸出日誌事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。

 

 

 

Spring整合log4j

<listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
 </listener>

<context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>/WEB-INF/log4j.xml</param-value>
 </context-param>

 

   

 

 

其他參考:

 

http://blog.csdn.net/jemmy/archive/2007/11/16/1889114.aspx

http://baike.baidu.com/view/25347.htm#sub25347

LOG4J官方文檔  F:/學習資料/學習文檔/開源文檔/apache-log4j-1.2.16

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章