【轉】java日誌組件介紹(common-logging,log4j,slf4j,logback )

來源:互聯網
上載者:User

標籤:有趣   oar   進程   for   this   png   apach   曆史   str   

common-logging

common-logging是apache提供的一個通用的日誌介面。使用者可以自由選擇第三方的日誌組件作為具體實現,像log4j,或者jdk內建的logging, common-logging會通過動態尋找的機制,在程式運行時自動找出真正使用的日誌庫。當然,common-logging內部有一個Simple logger的簡單實現,但是功能很弱。所以使用common-logging,通常都是配合著log4j來使用。使用它的好處就是,代碼依賴是common-logging而非log4j, 避免了和具體的日誌方案直接耦合,在有必要時,可以變更記錄檔實現的第三方庫。

 

使用common-logging的常見代碼: [java] view plaincopyprint?
  1. import org.apache.commons.logging.Log;  
  2. import org.apache.commons.logging.LogFactory;  
  3.   
  4. public class A {  
  5.     private static Log logger = LogFactory.getLog(this.getClass());  
  6. }  
import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;public class A {private static Log logger = LogFactory.getLog(this.getClass());}
動態尋找原理:Log 是一個介面聲明。LogFactory 的內部會去裝載具體的日誌系統,並獲得實現該Log 介面的實作類別。LogFactory 內部裝載日誌系統的流程如下:
  1. 首先,尋找org.apache.commons.logging.LogFactory 屬性配置。
  2. 否則,利用JDK1.3 開始提供的service 發現機制,會掃描classpah 下的META-INF/services/org.apache.commons.logging.LogFactory檔案,若找到則裝載裡面的配置,使用裡面的配置。
  3. 否則,從Classpath 裡尋找commons-logging.properties ,找到則根據裡面的配置載入。
  4. 否則,使用預設的配置:如果能找到Log4j 則預設使用log4j 實現,如果沒有則使用JDK14Logger 實現,再沒有則使用commons-logging 內部提供的SimpleLog 實現。
從上述載入流程來看,只要引入了log4j 並在classpath 配置了log4j.xml ,則commons-logging 就會使log4j 使用正常,而代碼裡不需要依賴任何log4j 的代碼。

 

slf4j

slf4j全稱為Simple Logging Facade for JAVA,java簡單日誌門面。類似於Apache Common-Logging,是對不同日誌架構提供的一個門面封裝,可以在部署的時候不修改任何配置即可接入一種日誌實現方案。但是,他在編譯時間靜態繫結真正的Log庫。使用SLF4J時,如果你需要使用某一種日誌實現,那麼你必須選擇正確的SLF4J的jar包的集合(各種橋接包)。

使用slf4j的常見代碼:

[java] view plaincopyprint?
  1. import org.slf4j.Logger;  
  2. import org.slf4j.LoggerFactory;  
  3.   
  4. public class A {  
  5.     private static Log logger = LogFactory.getLog(this.getClass());  
  6. }  
import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class A {private static Log logger = LogFactory.getLog(this.getClass());}


slf4j靜態繫結原理:SLF4J 會在編譯時間會綁定import org.slf4j.impl.StaticLoggerBinder; 該類裡面實現對具體日誌方案的綁定接入。任何一種基於slf4j 的實現都要有一個這個類。如:org.slf4j.slf4j-log4j12-1.5.6: 提供對 log4j 的一種適配實現。注意:如果有任意兩個實現slf4j 的包同時出現,那麼就可能出現問題。
 

 

slf4j 與 common-logging 比較 common-logging通過動態尋找的機制,在程式運行時自動找出真正使用的日誌庫。由於它使用了ClassLoader尋找和載入底層的日誌庫, 導致了象OSGI這樣的架構無法正常工作,因為OSGI的不同的外掛程式使用自己的ClassLoader。 OSGI的這種機制保證了外掛程式互相獨立,然而卻使Apache Common-Logging無法工作。
slf4j在編譯時間靜態繫結真正的Log庫,因此可以再OSGI中使用。另外,SLF4J 支援參數化的log字串,避免了之前為了減少字串拼接的效能損耗而不得不寫的if(logger.isDebugEnable()),現在你可以直接寫:logger.debug(“current user is: {}”, user)。拼裝訊息被延遲到了它能夠確定是不是要顯示這條訊息的時候,但是擷取參數的代價並沒有倖免。 Log4j Apache的一個開放原始碼項目,通過使用Log4j,我們可以控制日誌資訊輸送的目的地是控制台、檔案、GUI組件、甚至是套介面服務 器、NT的事件記錄器、UNIX Syslog守護進程等;使用者也可以控制每一條日誌的輸出格式;通過定義每一條日誌資訊的層級,使用者能夠更加細緻地控制日誌的產生過程。這些可以通過一個 設定檔來靈活地進行配置,而不需要修改程式碼。
 LogBack Logback是由log4j創始人設計的又一個開源日記組件。logback當前分成三個模組:logback-core,logback- classic和logback-access。logback-core是其它兩個模組的基礎模組。logback-classic是log4j的一個 改良版本。此外logback-classic完整實現SLF4J API使你可以很方便地更換成其它日記系統如log4j或JDK14 Logging。logback-access訪問模組與Servlet容器整合提供通過Http來訪問日記的功能。
 Log4j 與 LogBack 比較LogBack作為一個通用可靠、快速靈活的日誌架構,將作為Log4j的替代和SLF4J組成新的日誌系統的完整實現。LOGBack聲稱具有極佳的效能,“ 某些關鍵操作,比如判定是否記錄一條日誌語句的操作,其效能得到了顯著的提高。這個操作在LogBack中需要3納秒,而在Log4J中則需要30納秒。 LogBack建立記錄器(logger)的速度也更快:13微秒,而在Log4J中需要23微秒。更重要的是,它擷取已存在的記錄器只需94納秒,而 Log4J需要2234納秒,時間減少到了1/23。跟JUL相比的效能提高也是顯著的”。 另外,LOGBack的所有文檔是全面免費提供的,不象Log4J那樣只提供部分免費文檔而需要使用者去購買付費文檔。  slf4j與其他各種日誌組件的橋接 應用代碼中使用slf4j介面,接入具體實現的方法 應用代碼中使用別的日誌介面,轉成slf4j的方法
 日誌組件相關曆史Java 界裡有許多實現日誌功能的工具,最早得到廣泛使用的是 log4j,許多應用程式的日誌部分都交給了 log4j,不過作為組件開發人員,他們希望自己的組件不要緊緊依賴某一個工具,畢竟在同一個時候還有很多其他很多日誌工具,假如一個應用程式用到了兩個組件,恰好兩個組件使用不同的日誌工具,那麼應用程式就會有兩份日誌輸出了。

為瞭解決這個問題,Apache Commons Logging (之前叫 Jakarta Commons Logging,JCL)粉墨登場,JCL 只提供 log 介面,具體的實現則在運行時動態尋找。這樣一來組件開發人員只需要針對 JCL 介面開發,而調用組件的應用程式則可以在運行時搭配自己喜好的日誌實踐工具。

所以即使到現在你仍會看到很多程式應用 JCL + log4j 這種搭配,不過當程式規模越來越龐大時,JCL的動態綁定並不是總能成功,具體原因大家可以 Google 一下,這裡就不再贅述了。解決方案之一就是在程式部署時靜態繫結指定的日誌工具,這就是 SLF4J 產生的原因。

跟 JCL 一樣,SLF4J 也是只提供 log 介面,具體的實現是在打包應用程式時所放入的綁定器(名字為 slf4j-XXX-version.jar)來決定,XXX 可以是 log4j12, jdk14, jcl, nop 等,他們實現了跟具體日誌工具(比如 log4j)的綁定及代理工作。舉個例子:如果一個程式希望用 log4j 日誌工具,那麼程式只需針對 slf4j-api 介面編程,然後在打包時再放入 slf4j-log4j12-version.jar 和 log4j.jar 就可以了。

現在還有一個問題,假如你正在開發應用程式所調用的組件當中已經使用了 JCL 的,還有一些組建可能直接調用了 java.util.logging,這時你需要一個橋接器(名字為 XXX-over-slf4j.jar)把他們的日誌輸出重新導向到 SLF4J,所謂的橋接器就是一個假的日誌實現工具,比如當你把 jcl-over-slf4j.jar 放到 CLASS_PATH 時,即使某個組件原本是通過 JCL 輸出日誌的,現在卻會被 jcl-over-slf4j “騙到”SLF4J 裡,然後 SLF4J 又會根據綁定器把日誌交給具體的日誌實現工具。過程如下

Component
|
| log to Apache Commons Logging
V
jcl-over-slf4j.jar --- (redirect) ---> SLF4j ---> slf4j-log4j12-version.jar ---> log4j.jar ---> 輸出日誌

看到上面的流程圖可能會發現一個有趣的問題,假如在 CLASS_PATH 裡同時放置 log4j-over-slf4j.jar 和 slf4j-log4j12-version.jar 會發生什麼情況呢?沒錯,日誌會被踢來踢去,最終進入死迴圈。

所以使用 SLF4J 的比較典型搭配就是把 slf4j-api、JCL 橋接器、java.util.logging(JUL)橋接器、log4j 綁定器、log4j 這5個 jar 放置在 CLASS_PATH 裡。

不過並不是所有APP容器都是使用 log4j 的,比如 Google AppEngine 它使用的是 java.util.logging(JUL),這時應用 SLF4J 的搭配就變成 slf4j-api、JCL橋接器、logj4橋接器、JUL綁定器這4個 jar 放置在 WEB-INF/lib 裡。

【轉】java日誌組件介紹(common-logging,log4j,slf4j,logback )

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.