<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    瘋狂的java
    好的藝術(shù)家復(fù)制,偉大的藝術(shù)家偷竊!
    posts - 3,  comments - 4,  trackbacks - 0

    common-logging

    common-logging是apache提供的一個(gè)通用的日志接口。用戶可以自由選擇第三方的日志組件作為具體實(shí)現(xiàn),像log4j,或者jdk自帶的logging, common-logging會(huì)通過動(dòng)態(tài)查找的機(jī)制,在程序運(yùn)行時(shí)自動(dòng)找出真正使用的日志庫。當(dāng)然,common-logging內(nèi)部有一個(gè)Simple logger的簡單實(shí)現(xiàn),但是功能很弱。所以使用common-logging,通常都是配合著log4j來使用。使用它的好處就是,代碼依賴是common-logging而非log4j, 避免了和具體的日志方案直接耦合,在有必要時(shí),可以更改日志實(shí)現(xiàn)的第三方庫。

    使用common-logging的常見代碼:
    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. }  
    動(dòng)態(tài)查找原理:Log 是一個(gè)接口聲明。LogFactory 的內(nèi)部會(huì)去裝載具體的日志系統(tǒng),并獲得實(shí)現(xiàn)該Log 接口的實(shí)現(xiàn)類。LogFactory 內(nèi)部裝載日志系統(tǒng)的流程如下:
    1. 首先,尋找org.apache.commons.logging.LogFactory 屬性配置。
    2. 否則,利用JDK1.3 開始提供的service 發(fā)現(xiàn)機(jī)制,會(huì)掃描classpah 下的META-INF/services/org.apache.commons.logging.LogFactory文件,若找到則裝載里面的配置,使用里面的配置。
    3. 否則,從Classpath 里尋找commons-logging.properties ,找到則根據(jù)里面的配置加載。
    4. 否則,使用默認(rèn)的配置:如果能找到Log4j 則默認(rèn)使用log4j 實(shí)現(xiàn),如果沒有則使用JDK14Logger 實(shí)現(xiàn),再?zèng)]有則使用commons-logging 內(nèi)部提供的SimpleLog 實(shí)現(xiàn)。
    從上述加載流程來看,只要引入了log4j 并在classpath 配置了log4j.xml ,則commons-logging 就會(huì)使log4j 使用正常,而代碼里不需要依賴任何log4j 的代碼。

    slf4j

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

    使用slf4j的常見代碼:

    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. }  

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

    slf4j 與 common-logging 比較

    common-logging通過動(dòng)態(tài)查找的機(jī)制,在程序運(yùn)行時(shí)自動(dòng)找出真正使用的日志庫。由于它使用了ClassLoader尋找和載入底層的日志庫, 導(dǎo)致了象OSGI這樣的框架無法正常工作,因?yàn)镺SGI的不同的插件使用自己的ClassLoader。 OSGI的這種機(jī)制保證了插件互相獨(dú)立,然而卻使Apache Common-Logging無法工作。

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

    Log4j

    Apache的一個(gè)開放源代碼項(xiàng)目,通過使用Log4j,我們可以控制日志信息輸送的目的地是控制臺(tái)、文件、GUI組件、甚至是套接口服務(wù) 器、NT的事件記錄器、UNIX Syslog守護(hù)進(jìn)程等;用戶也可以控制每一條日志的輸出格式;通過定義每一條日志信息的級(jí)別,用戶能夠更加細(xì)致地控制日志的生成過程。這些可以通過一個(gè) 配置文件來靈活地進(jìn)行配置,而不需要修改程序代碼。

    LogBack

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

    Log4j 與 LogBack 比較

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

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

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

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


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

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

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

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

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

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

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

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

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

    不過并不是所有APP容器都是使用 log4j 的,比如 Google AppEngine 它使用的是 java.util.logging(JUL),這時(shí)應(yīng)用 SLF4J 的搭配就變成 slf4j-api、JCL橋接器、logj4橋接器、JUL綁定器這4個(gè) jar 放置在 WEB-INF/lib 里。
    posted on 2014-04-13 09:49 永志歌德 閱讀(14911) 評(píng)論(4)  編輯  收藏

    FeedBack:
    # re: java日志組件介紹(common-logging,log4j,slf4j,logback )
    2015-09-02 13:16 | digdeep
    關(guān)于Java 日志最好的介紹。轉(zhuǎn)載過去。  回復(fù)  更多評(píng)論
      
    # re: java日志組件介紹(common-logging,log4j,slf4j,logback )
    2015-11-11 16:47 | chageme
    lihai ,拿走  回復(fù)  更多評(píng)論
      
    # re: java日志組件介紹(common-logging,log4j,slf4j,logback )
    2015-11-23 12:27 | archerwq
    贊一個(gè),詳細(xì)代碼示例可參考這個(gè):http://www.archerwq.com/java_logging_integrate_slf4j_and_logback/  回復(fù)  更多評(píng)論
      
    # re: java日志組件介紹(common-logging,log4j,slf4j,logback )
    2016-06-25 16:08 | zxp
    很清晰,謝謝。  回復(fù)  更多評(píng)論
      

    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     

    <2015年9月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    常用鏈接

    留言簿

    隨筆分類

    隨筆檔案

    文章檔案

    收藏夾

    我的博客

    牛人博客

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 国产男女猛烈无遮挡免费视频| 1000部羞羞禁止免费观看视频 | 亚洲精品午夜无码电影网| 边摸边脱吃奶边高潮视频免费| 97人伦色伦成人免费视频| 日韩亚洲产在线观看| 欧美男同gv免费网站观看| 亚洲激情视频图片| 成人免费网站在线观看| 无码亚洲成a人在线观看| 免费观看午夜在线欧差毛片| 杨幂最新免费特级毛片| 中文字幕亚洲日韩无线码| 99视频免费在线观看| 亚洲人成电影福利在线播放| 国产免费的野战视频| 亚洲国产成人久久综合| 五月婷婷亚洲综合| 中文字幕不卡高清免费| 亚洲精品午夜在线观看| 全免费a级毛片免费**视频| 免费人成大片在线观看播放电影| 国产亚洲精久久久久久无码77777 国产亚洲精品成人AA片新蒲金 | 国产精品日本亚洲777| 国产精品亚洲αv天堂无码| 精品国产一区二区三区免费| 亚洲精品人成电影网| 国产在线98福利播放视频免费| 91av免费在线视频| 亚洲一级毛片免费看| 亚洲AⅤ优女AV综合久久久| 免费在线看黄的网站| 亚洲AV色吊丝无码| 国产日产亚洲系列最新| 日本黄网站动漫视频免费| 亚洲av无码一区二区三区人妖| 久久精品视频亚洲| 国产又大又黑又粗免费视频| 久久精品国产免费一区| 亚洲高清毛片一区二区| 亚洲人成依人成综合网|