一直使用log4j來記錄日誌,可是一直以來沒有深刻研究過log4j,最近研究了下log4j,下面總結一下:java
log4j配置:apache
1. 配置根Logger,其語法爲: app
log4j.rootLogger = [level] , appenderName1, appenderName2, …
其中,level 是日誌記錄的優先級,分爲 OFF、FATAL、ERROR、WARN、INFO、
DEBUG、ALL 或者您定義的級別。Log4j 建議只使用四個級別,優先級從高到低分
別是 ERROR、WARN、INFO、DEBUG。
2. 配置日誌信息輸出目的地Appender,其語法爲:ide
log4j.appender.appenderName = fully.qualified.name.of.appender.class log4j.appender.appenderName.option1 = value1 … log4j.appender.appenderName.option = valueN
其中,Log4j 提供的appender有如下幾種:
org.apache.log4j.ConsoleAppender(控制檯),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(天天產生一個日誌文件),
org.apache.log4j.RollingFileAppender (文件大小到達指定尺寸的時候產生一個新的文件),
org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)
3. 配置日誌信息的格式(佈局),其語法爲:函數
log4j.appender.appenderName.layout= fully.qualified.name.of.layout.class log4j.appender.appenderName.layout.option1 = value1 … log4j.appender.appenderName.layout.option = valueN
其中,Log4j 提供的layout有如下幾種:
org.apache.log4j.HTMLLayout(以HTML 表格形式佈局),
org.apache.log4j.PatternLayout(能夠靈活地指定佈局模式),
org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),
org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)
Log4J 採用相似 C 語言中的 printf 函數的打印格式格式化日誌信息,打印參數以下:
%m 輸出代碼中指定的消息
%p 輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL
%r 輸出自應用啓動到輸出該log信息耗費的毫秒數
%c 輸出所屬的類目,一般就是所在類的全名
%t 輸出產生該日誌事件的線程名
%n 輸出一個回車換行符,Windows平臺爲「\r\n」,Unix 平臺爲「\n」
%d 輸出日誌時間點的日期或時間,默認格式爲 ISO8601,也能夠在其後指定格式,好比:%d{yyy MMM dd HH:mm:ss,SSS},輸出相似:2002 年10 月18 日 22:10:28,921
%l 輸出日誌事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(TestLog4.java:10) 佈局
在代碼中使用Log4j
1. 獲得記錄器
使用Log4j, 第一步就是獲取日誌記錄器, 這個記錄器將負責控制日誌信息。其語法爲:
測試
public static Logger getLogger( String name) public static Logger getLogger( Class clazz) ``` getLogger( Class class)//其實調用的是getLogger(class.getName())
2. 插入記錄信息(格式化日誌信息)
當上兩個必要步驟執行完畢,您就能夠輕鬆地使用不一樣優先級別的
語句插入到您想記錄日誌的任何地方,其語法以下:ui
Logger.debug ( Object message ) ; Logger.info ( Object message ) ; Logger.warn ( Object message ) ; Logger.error ( Object message ) ;
深刻Log4jthis
1. Log4j總結
全部的logger都會繼承rootLogger,logger經過名字中的"."來肯定繼承關係,如com.test繼承com。
經過Logger logger =Logger.getLogger(loggerName)獲取logger時,Log4j首先檢查配置文件中是否存在名爲loggerName的logger,若存在則返回這個logger;若不存在則新建一個名爲loggerName的logger並繼承離它最近的父logger直到rootLogger。
關於loggerName的命名,最佳實踐爲按類名命名。spa
log4j.rootLogger=INFO,Console log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern= %d{yyyy-MM-dd HH:mm:ss} %x %-5p [%c{3}] %m%n ###自定義logger名爲cn.hdt同時會繼承rootLogger的appender,即包cn.hdt下的日子寫入文件和控制檯 log4j.logger.cn.hdt=info,File log4j.appender.File=org.apache.log4j.FileAppender log4j.appender.File.File=logs/catalina.out log4j.appender.File.Append=true log4j.appender.File.DatePattern='.'yyyy-MM-dd log4j.appender.File.layout=org.apache.log4j.PatternLayout log4j.appender.File.layout.ConversionPattern=%d{ABSOLUTE} %-5p [%c] %m%n ###自定義logger名爲com.test,修改日誌記錄級別爲error,即包com.test下的error日誌會被打印 log4j.logger.com.test=error
2. 自定義appender
自定義log4j appender須要繼承log4j公共的基類AppenderSkeleton並實現下列方法:
demo代碼:
package cn.hdt; import org.apache.log4j.AppenderSkeleton; import org.apache.log4j.spi.LoggingEvent; public class MyAppender extends AppenderSkeleton{ private String account ; public String getAccount() { return account; } public void setAccount(String account) { this.account = account; } @Override protected void append(LoggingEvent event) { System.out.println("Hello, " + account + " : "+ event.getMessage()); } @Override public void close() { } @Override public boolean requiresLayout() { return false; } @Override public void activateOptions() { System.out.print("myappender init"); } }
配置文件:
log4j.rootLogger=INFO,hello log4j.appender.hello=org.apache.log4j.ConsoleAppender log4j.appender.hello.layout=org.apache.log4j.PatternLayout log4j.appender.hello.layout.ConversionPattern= %d{yyyy-MM-dd HH:mm:ss} %x %-5p [%c{3}] %m%n log4j.appender.hello=cn.hdt.MyAppender log4j.appender.hello.account=World
測試代碼:
package cn.hdt; import org.apache.log4j.Logger; public class LogTest { public static void main(String[] args) { Logger logger = Logger.getLogger(LogTest.class); logger.info("this is info") ; } }
執行main函數,輸出結果:
Myappender init Hello, World : this is info
因爲未實現佈局格式,因此輸出爲未格式化;MyAppender帶有一個account的屬性,可在配置文件中指定該屬性的值,經過appenderName後加".propertyName = value"指定,如log4j.appender.hello.account=World。
注意爲了給MyAppender的account注入值,MyAppender中必須有account的setter方法。
關於log4j的xml配置方法和property配置大致差很少