java日志組件介紹(common-logging徒欣,log4j,slf4j蜗字,logback)

轉(zhuǎn)自:http://www.blogjava.net/daiyongzhi/archive/2014/04/13/412364.html

common-logging

common-logging是apache提供的一個通用的日志接口打肝。用戶可以自由選擇第三方的日志組件作為具體實現(xiàn),像log4j挪捕,或者jdk自帶的logging粗梭, common-logging會通過動態(tài)查找的機制,在程序運行時自動找出真正使用的日志庫级零。當然断医,common-logging內(nèi)部有一個Simple logger的簡單實現(xiàn),但是功能很弱妄讯。所以使用common-logging孩锡,通常都是配合著log4j來使用。使用它的好處就是亥贸,代碼依賴是common-logging而非log4j躬窜, 避免了和具體的日志方案直接耦合,在有必要時炕置,可以更改日志實現(xiàn)的第三方庫荣挨。

使用common-logging的常見代碼:

import org.apache.commons.logging.Log;  
import org.apache.commons.logging.LogFactory;  
  
public class A {  
    private static Log logger = LogFactory.getLog(this.getClass());  
}  

動態(tài)查找原理:
Log 是一個接口聲明男韧。LogFactory 的內(nèi)部會去裝載具體的日志系統(tǒng),并獲得實現(xiàn)該Log 接口的實現(xiàn)類默垄。LogFactory 內(nèi)部裝載日志系統(tǒng)的流程如下:

  1. 首先此虑,尋找org.apache.commons.logging.LogFactory 屬性配置。
  2. 否則口锭,利用JDK1.3 開始提供的service 發(fā)現(xiàn)機制朦前,會掃描classpah 下的META-INF/services/org.apache.commons.logging.LogFactory文件,若找到則裝載里面的配置鹃操,使用里面的配置韭寸。
  3. 否則,從Classpath 里尋找commons-logging.properties 荆隘,找到則根據(jù)里面的配置加載恩伺。
  4. 否則,使用默認的配置:如果能找到Log4j 則默認使用log4j 實現(xiàn)椰拒,如果沒有則使用JDK14Logger 實現(xiàn)晶渠,再沒有則使用commons-logging 內(nèi)部提供的SimpleLog 實現(xiàn)。

從上述加載流程來看燃观,只要引入了log4j 并在classpath 配置了log4j.xml 褒脯,則commons-logging 就會使log4j 使用正常,而代碼里不需要依賴任何log4j 的代碼仪壮。

slf4j

slf4j全稱為Simple Logging Facade for JAVA憨颠,java簡單日志門面。類似于Apache Common-Logging积锅,是對不同日志框架提供的一個門面封裝,可以在部署的時候不修改任何配置即可接入一種日志實現(xiàn)方案养盗。但是缚陷,他在編譯時靜態(tài)綁定真正的Log庫。使用SLF4J時往核,如果你需要使用某一種日志實現(xiàn)箫爷,那么你必須選擇正確的SLF4J的jar包的集合(各種橋接包)。

使用slf4j的常見代碼:

import org.slf4j.Logger;  
import org.slf4j.LoggerFactory;  
  
public class A {  
    private static Log logger = LogFactory.getLog(this.getClass());  
}  

slf4j靜態(tài)綁定原理:
SLF4J 會在編譯時會綁定import org.slf4j.impl.StaticLoggerBinder; 該類里面實現(xiàn)對具體日志方案的綁定接入聂儒。任何一種基于slf4j 的實現(xiàn)都要有一個這個類虎锚。如:org.slf4j.slf4j-log4j12-1.5.6: 提供對 log4j 的一種適配實現(xiàn)。注意:如果有任意兩個實現(xiàn)slf4j 的包同時出現(xiàn)衩婚,那么就可能出現(xiàn)問題窜护。

slf4j 與 common-logging 比較

  • common-logging
    通過動態(tài)查找的機制,在程序運行時自動找出真正使用的日志庫非春。由于它使用了ClassLoader尋找和載入底層的日志庫柱徙, 導(dǎo)致了象OSGI這樣的框架無法正常工作缓屠,因為OSGI的不同的插件使用自己的ClassLoader。 OSGI的這種機制保證了插件互相獨立护侮,然而卻使Apache Common-Logging無法工作敌完。

  • slf4j 在編譯時靜態(tài)綁定真正的Log庫,因此可以再OSGI中使用。另外羊初,SLF4J 支持參數(shù)化的log字符串滨溉,避免了之前為了減少字符串拼接的性能損耗而不得不寫的if(logger.isDebugEnable()),現(xiàn)在你可以直接寫:logger.debug(“current user is: {}”, user)长赞。拼裝消息被推遲到了它能夠確定是不是要顯示這條消息的時候业踏,但是獲取參數(shù)的代價并沒有幸免。

Log4j

Apache的一個開放源代碼項目涧卵,通過使用Log4j勤家,我們可以控制日志信息輸送的目的地是控制臺、文件柳恐、GUI組件伐脖、甚至是套接口服務(wù) 器、NT的事件記錄器乐设、UNIX Syslog守護進程等讼庇;用戶也可以控制每一條日志的輸出格式;通過定義每一條日志信息的級別近尚,用戶能夠更加細致地控制日志的生成過程蠕啄。這些可以通過一個 配置文件來靈活地進行配置,而不需要修改程序代碼戈锻。

LogBack

Logback是由log4j創(chuàng)始人設(shè)計的又一個開源日記組件歼跟。logback當前分成三個模塊:logback-core,logback- classic和logback-access。logback-core是其它兩個模塊的基礎(chǔ)模塊格遭。logback-classic是log4j的一個 改良版本哈街。此外logback-classic完整實現(xiàn)SLF4J API使你可以很方便地更換成其它日記系統(tǒng)如log4j或JDK14 Logging。logback-access訪問模塊與Servlet容器集成提供通過Http來訪問日記的功能拒迅。

Log4j 與 LogBack 比較

LogBack作為一個通用可靠骚秦、快速靈活的日志框架,將作為Log4j的替代和SLF4J組成新的日志系統(tǒng)的完整實現(xiàn)璧微。LOGBack聲稱具有極佳的性能作箍,“ 某些關(guān)鍵操作,比如判定是否記錄一條日志語句的操作前硫,其性能得到了顯著的提高胞得。這個操作在LogBack中需要3納秒,而在Log4J中則需要30納秒开瞭。 LogBack創(chuàng)建記錄器(logger)的速度也更快:13微秒懒震,而在Log4J中需要23微秒罩息。更重要的是,它獲取已存在的記錄器只需94納秒个扰,而 Log4J需要2234納秒瓷炮,時間減少到了1/23。跟JUL相比的性能提高也是顯著的”递宅。 另外娘香,LOGBack的所有文檔是全面免費提供的,不象Log4J那樣只提供部分免費文檔而需要用戶去購買付費文檔办龄。

slf4j與其他各種日志組件的橋接

應(yīng)用代碼中使用slf4j接口烘绽,接入具體實現(xiàn)的方法

slf4j與其他各種日志組件的橋接

應(yīng)用代碼中使用別的日志接口,轉(zhuǎn)成slf4j的方法

slf4j與其他各種日志組件的橋接

日志組件相關(guān)歷史

Java 界里有許多實現(xiàn)日志功能的工具俐填,最早得到廣泛使用的是 log4j安接,許多應(yīng)用程序的日志部分都交給了 log4j,不過作為組件開發(fā)者英融,他們希望自己的組件不要緊緊依賴某一個工具盏檐,畢竟在同一個時候還有很多其他很多日志工具,假如一個應(yīng)用程序用到了兩個組件驶悟,恰好兩個組件使用不同的日志工具胡野,那么應(yīng)用程序就會有兩份日志輸出了。

為了解決這個問題痕鳍,Apache Commons Logging (之前叫 Jakarta Commons Logging硫豆,JCL)粉墨登場,JCL 只提供 log 接口笼呆,具體的實現(xiàn)則在運行時動態(tài)尋找熊响。這樣一來組件開發(fā)者只需要針對 JCL 接口開發(fā),而調(diào)用組件的應(yīng)用程序則可以在運行時搭配自己喜好的日志實踐工具抄邀。

所以即使到現(xiàn)在你仍會看到很多程序應(yīng)用 JCL + log4j 這種搭配耘眨,不過當程序規(guī)模越來越龐大時,JCL的動態(tài)綁定并不是總能成功境肾,具體原因大家可以 Google 一下山林,這里就不再贅述了懂版。解決方法之一就是在程序部署時靜態(tài)綁定指定的日志工具刷喜,這就是 SLF4J 產(chǎn)生的原因旬迹。

跟 JCL 一樣设江,SLF4J 也是只提供 log 接口声畏,具體的實現(xiàn)是在打包應(yīng)用程序時所放入的綁定器(名字為 slf4j-XXX-version.jar)來決定等脂,XXX 可以是 log4j12, jdk14, jcl, nop 等嗅辣,他們實現(xiàn)了跟具體日志工具(比如 log4j)的綁定及代理工作憎兽。舉個例子:如果一個程序希望用 log4j 日志工具冷离,那么程序只需針對 slf4j-api 接口編程吵冒,然后在打包時再放入 slf4j-log4j12-version.jar 和 log4j.jar 就可以了。

現(xiàn)在還有一個問題西剥,假如你正在開發(fā)應(yīng)用程序所調(diào)用的組件當中已經(jīng)使用了 JCL 的痹栖,還有一些組建可能直接調(diào)用了 java.util.logging,這時你需要一個橋接器(名字為 XXX-over-slf4j.jar)把他們的日志輸出重定向到 SLF4J瞭空,所謂的橋接器就是一個假的日志實現(xiàn)工具揪阿,比如當你把 jcl-over-slf4j.jar 放到 CLASS_PATH 時,即使某個組件原本是通過 JCL 輸出日志的咆畏,現(xiàn)在卻會被 jcl-over-slf4j “騙到”SLF4J 里南捂,然后 SLF4J 又會根據(jù)綁定器把日志交給具體的日志實現(xiàn)工具。過程如下

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

看到上面的流程圖可能會發(fā)現(xiàn)一個有趣的問題旧找,假如在 CLASS_PATH 里同時放置 log4j-over-slf4j.jar 和 slf4j-log4j12-version.jar 會發(fā)生什么情況呢溺健?沒錯,日志會被踢來踢去钮蛛,最終進入死循環(huán)鞭缭。

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

不過并不是所有APP容器都是使用 log4j 的易结,比如 Google AppEngine 它使用的是 java.util.logging(JUL),這時應(yīng)用 SLF4J 的搭配就變成 slf4j-api柜候、JCL橋接器搞动、logj4橋接器、JUL綁定器這4個 jar 放置在 WEB-INF/lib 里渣刷。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鹦肿,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子辅柴,更是在濱河造成了極大的恐慌箩溃,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件碌嘀,死亡現(xiàn)場離奇詭異涣旨,居然都是意外死亡,警方通過查閱死者的電腦和手機股冗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門霹陡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事烹棉≡芘” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵浆洗,是天一觀的道長催束。 經(jīng)常有香客問我,道長辅髓,這世上最難降的妖魔是什么泣崩? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮洛口,結(jié)果婚禮上矫付,老公的妹妹穿的比我還像新娘。我一直安慰自己第焰,他們只是感情好买优,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著挺举,像睡著了一般杀赢。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上湘纵,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天脂崔,我揣著相機與錄音,去河邊找鬼梧喷。 笑死砌左,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的铺敌。 我是一名探鬼主播汇歹,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼偿凭!你這毒婦竟也來了产弹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤弯囊,失蹤者是張志新(化名)和其女友劉穎痰哨,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體匾嘱,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡作谭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了奄毡。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡贝或,死狀恐怖吼过,靈堂內(nèi)的尸體忽然破棺而出锐秦,到底是詐尸還是另有隱情,我是刑警寧澤盗忱,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布酱床,位于F島的核電站,受9級特大地震影響趟佃,放射性物質(zhì)發(fā)生泄漏扇谣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一闲昭、第九天 我趴在偏房一處隱蔽的房頂上張望罐寨。 院中可真熱鬧,春花似錦序矩、人聲如沸鸯绿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瓶蝴。三九已至,卻和暖如春租幕,著一層夾襖步出監(jiān)牢的瞬間舷手,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工劲绪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留男窟,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓珠叔,卻偏偏與公主長得像蝎宇,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子祷安,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容