關於文件中配置的每一個部分的大體做用:html
#將日誌級別爲Debug的日誌信息輸出到CONSOLE,R(CONSOLE和R是能夠任意起名的)
log4j.rootLogger=DEBUG, CONSOLE, R
#日誌等級可分爲OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL,若是配置OFF則不打出任何信息。
#定義名爲CONSOLE的輸出目的是哪一種類型:
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
#輸出的類型能夠是:
#org.apache.log4j.ConsoleAppender(控制檯),
#org.apache.log4j.FileAppender(文件),
#org.apache.log4j.DailyRollingFileAppender(天天產生一個日誌文件),
#org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件)
#org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)web
#指定CONSOLE的輸出端的layout的類型:
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
#layout的類型能夠是:
#org.apache.log4j.HTMLLayout(以HTML表格形式佈局),
#org.apache.log4j.PatternLayout(能夠靈活地指定佈局模式),
#org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),
#org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)sql
#指定具體的輸出格式
log4j.appender.CONSOLE.layout.ConversionPattern=[%p]%t-%c-%m%n數據庫
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.Append=true
log4j.appender.R.DatePattern='_'yyyy-MM-dd'.log'
log4j.appender.R.File=/home/tomcat/logs/ygzz.log
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.encoding=UTF-8
log4j.appender.R.layout.ConversionPattern=%d{yyyy:MM:dd:HH:mm:ss} %-5p [%C] (%F:%L) - %m%napache
#以包爲單位指定日誌級別:
指定ibatis.com包下全部的日誌級別爲debug
log4j.logger.com.ibatis=debugtomcat
日誌記錄器(Logger)是日誌處理的核心組件。log4j具備5種正常級別(Level)。:
1.static Level DEBUG :
DEBUG Level指出細粒度信息事件對調試應用程序是很是有幫助的。
2.static Level INFO
INFO level代表 消息在粗粒度級別上突出強調應用程序的運行過程。
3.static Level WARN
WARN level代表會出現潛在錯誤的情形。
4.static Level ERROR
ERROR level指出雖然發生錯誤事件,但仍然不影響系統的繼續運行。
5.static Level FATAL
FATAL level指出每一個嚴重的錯誤事件將會致使應用程序的退出。oracle
另外,還有兩個可用的特別的日誌記錄級別:
1.static Level ALL
ALL Level是最低等級的,用於打開全部日誌記錄。
2.static Level OFF
OFF Level是最高等級的,用於關閉全部日誌記錄。app
日誌記錄器(Logger)的行爲是分等級的:
分爲OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級別。Log4j建議只使用四個級別,優先級從高到低分別是 ERROR、WARN、INFO、DEBUG。經過在這裏定義的
級別,您能夠控制到應用程序中相應級別的日誌信息的開關。好比在這裏定義了INFO級別, 則應用程序中全部DEBUG級別的日誌信息將不被打印出來。
優先級高的將被打印出來。項目上生產環境時候必定得把debug的日誌級別從新調爲warn或者更高,避免產生大量日誌。socket
一句話總結:日誌的優先輸出順序是:ERROR、WARN、INFO、DEBUG;即:若是把模式設置爲info,則不會顯示debug的信息,一次類推佈局
示例的文件:
log4j.rootLogger=DEBUG,CONSOLE,DATABASE,FILE,ROLLING_FILE log4j.addivity.org.apache=true # 應用於控制檯 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.Threshold=INFO log4j.appender.CONSOLE.Target=System.out log4j.appender.CONSOLE.Encoding=GBK 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.DATABASE=org.apache.log4j.jdbc.JDBCAppender log4j.appender.DATABASE.URL=jdbc:oracle:thin:@90.0.12.20:1521:ORCL log4j.appender.DATABASE.driver=oracle.jdbc.driver.OracleDriver log4j.appender.DATABASE.user=Nation log4j.appender.DATABASE.password=1 log4j.appender.CONSOLE.Threshold=WARN log4j.appender.DATABASE.sql=INSERT INTO LOG4J(stamp,thread,infolevel,class,messages) VALUES ('%d{yyyy-MM-dd HH:mm:ss}', '%t', '%p', '%l','%m') # INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c%x - %m%n') # 寫入數據庫中的表LOG4J的Message字段中,內容%d(日期)%c:日誌信息所在地(類名)%p:日誌信息級別%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.FILE=org.apache.log4j.FileAppender log4j.appender.FILE.File=C:/log4j/file.log log4j.appender.FILE.Append=false log4j.appender.FILE.Encoding=GBK log4j.appender.FILE.layout=org.apache.log4j.PatternLayout log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p%c %x - %m%n # 應用於文件回滾 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.Encoding=GBK 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 # 天天新建日誌 log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender log4j.appender.A1.File=C:/log4j/log log4j.appender.A1.Encoding=GBK log4j.appender.A1.Threshold=DEBUG log4j.appender.A1.DatePattern='.'yyyy-MM-dd log4j.appender.A1.layout=org.apache.log4j.PatternLayout log4j.appender.A1.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L : %m%n #自定義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 #應用於socket log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender log4j.appender.SOCKET.RemoteHost=localhost log4j.appender.SOCKET.Port=5001 log4j.appender.SOCKET.LocationInfo=true log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout log4j.appender.SOCKET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n # LogFactor 5 Appender log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000 log4j.appender.LF5_APPENDER.layout=org.apache.log4j.PatternLayout log4j.appender.LF5_APPENDER.layout.ConversionPattern =[framework] %d - %c -%-4r[%t] %-5p %c %x - %m%n # 發送日誌給郵件 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