log4j學習總結

一直使用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並實現下列方法:

  •  打印日誌核心方法:abstract protected void append(LoggingEvent event);
  •  初始化加載資源:public void activateOptions(),默認實現爲空
  •  釋放資源:public void close()
  •  是否須要按格式輸出文本:public boolean requiresLayout()
  •  正常狀況下咱們只須要覆蓋append方法便可。而後就能夠在log4j中使用了

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配置大致差很少

相關文章
相關標籤/搜索