總結
將
commons-logging
和
Log4j
的
jar
包都放置到
classpath
下,同時也將
Log4j
的配置文件放到
classpath
中,兩者就可以很好的合作。
采用
Log4j
配合
commons-logging
作為日志系統,是目前
Java
領域非常非常流行的模式,使用非常非常的普遍。兩者的結合帶來的結果就是:簡單
+
強大。
commons-logging
提供了簡捷、統一的接口,不需要額外配置,簡單;
Log4j
功能非常全面、強大;
commons-logging
僅僅對
Log4j(
當然還包括其它
LOG
實現
)
作了一層包裝,具體的日志輸出還是在內部轉交給身后的
Log4j
來處理;而
Log4j
雖然做了所有的事情,卻甘作綠葉,從不以真身示人。
兩者堪稱絕配。
對
log4j.properties
的一點介紹
下面對
log4j.properties
文件內容作一點點介紹,以后文所附
log4j.properties
文件為例:
除去以
#
開頭的注釋以及空行,第一行有用的內容是:
log4j.rootLogger = DEBUG, CONSOLE,A1
log4j.rootLogger
是最最重要的一個屬性了,它定義日志信息的“輸出級別”和“輸出目的地”。
關鍵看“
=
”后面的值,“
DEBUG, CONSOLE,A
1
”
這里我們要把它分成兩部分:第一個逗號之前的是第一部分,指定“輸出級別”;后面的是第二部分,指定“輸出目的地”。可以同時指定多個“輸出目的地”,以逗號隔開。
具體到上面這一行:它指定的“輸出級別”是“
DEBUG
”;它指定的“輸出目的地”是“
CONSOLE
”和“
A1
”。
注意:
l
????????
“輸出級別”有可選的五個值,分別是
DEBUG
、
INFO
、
WARN
、
ERROR
、
FATAL
,它們是由
Log4j
系統定義的。
l
????????
“輸出目的地”就是我們自己定義的了,就在
log4j.properties
的后面部分,此文件定義的“輸出目的地”有
CONSOLE
、
FILE
、
ROLLING_FILE
、
SOCKET
、
LF5_APPENDER
、
MAIL
、
DATABASE
、
A1
、
im
。該文件之所以可作主模板,就是因為它比較全面地定義了各種常見的輸出目的地(控制臺、文件、電子郵件、數據庫等)。
好,下面詳細解釋“
log4j.rootLogger=DEBUG, CONSOLE,A
1
”
這一行:
l????????
指定“輸出級別”是“
DEBUG
”,即,僅輸出級別大于等于“調試(
DEBUG
)”的日志信息
。如果此處指定的是“
WARN
”則僅調用
warn()
、
error()
、
fatal()
方法輸出的日志信息才被輸出到“輸出目的地”,而調用
debug()
、
info()
方法輸出的日志信息不被輸出到“輸出目的地”。明白了嗎?
Log4j
就是以這種方式來過濾控制日志信息的輸出與否,這也是對日志信息進行級別分類的目的。
l????????
指定“輸出目的地”是“
CONSOLE
”和“
A1
”,即,將指定的日志信息(根據日志級別已進行了過濾)同時輸出到的“控制臺”和“
SampleMessages.log4j
文件”。
?
?
附:一個有用的
log4j.properties
文件模板
##Log4J
的配置之簡單使它遍及于越來越多的應用中了
##Log4J
配置文件實現了輸出到控制臺、文件、回滾文件、發送日志郵件、輸出到數據庫日志表、自定義標簽等全套功能。擇其一二使用就夠用了。
##
此文件(
log4j.properties
)內容來自網絡,非本文作者
liigo
原創。
log4j.rootLogger=DEBUG, CONSOLE,A1
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] %-5p %c %x - %m%n
#log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n
#
應用于文件
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=file.log
log4j.appender.FILE.Append=false
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
# Use this layout for LogFactor 5 analysis
#
應用于文件回滾
log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
log4j.appender.ROLLING_FILE.Threshold=ERROR
log4j.appender.ROLLING_FILE.File=rolling.log
log4j.appender.ROLLING_FILE.Append=true
log4j.appender.ROLLING_FILE.MaxFileSize=10KB
log4j.appender.ROLLING_FILE.MaxBackupIndex=1
log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#
應用于
socket
log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender
log4j.appender.SOCKET.RemoteHost=localhost
log4j.appender.SOCKET.Port=5001
log4j.appender.SOCKET.LocationInfo=true
# Set up for Log Facter 5
log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout
log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n
# Log Factor 5 Appender
log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000
#
發送日志給郵件
log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
log4j.appender.MAIL.Threshold=FATAL
log4j.appender.MAIL.BufferSize=10
log4j.appender.MAIL.From=web@www.wuset.com
log4j.appender.MAIL.SMTPHost=www.wusetu.com
log4j.appender.MAIL.Subject=Log4J Message
log4j.appender.MAIL.To=web@www.wusetu.com
log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#
用于數據庫
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
log4j.appender.DATABASE.user=root
log4j.appender.DATABASE.password=
log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n')
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=SampleMessages.log4j
log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
#
自定義
Appender
log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
log4j.appender.im.host = mail.cybercorlin.net
log4j.appender.im.username = username
log4j.appender.im.password = password
log4j.appender.im.recipient = corlin@cybercorlin.net
log4j.appender.im.layout=org.apache.log4j.PatternLayout
log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n