最後更新于2017年02月09日
首先,配置log4j的jar,maven工程配置以下依賴,非maven工程從maven倉庫下載下傳jar添加到“build path”
然後,在src/main/java目錄(包的根目錄即classpath)建立log4j.properties檔案
最後,建立Main.java檔案
運作main方法,日志資訊就出來了
log4j.properties要放在哪以及怎樣配置才能被解析呢?不同工程類型配置方式不同
這是最常見的java工程類型,寫demo用的多,把log4j.properties放在src/main/java目錄(包的根目錄)就行了

web工程裡用spring mvc建構的比較多了,把log4j.properties放在src/main/resources的conf目錄(web工程配置檔案通常在resources或WEB-INF目錄),編輯web.xml,添加
沒有了spring提供的listener加載log4j.properties,我們要怎麼加載這個檔案呢?同樣,把log4j.properties放在src/main/resources的conf目錄,用servlet加載
編輯web.xml,添加
看着是不是和spring mvc的很像,甚至你也想到了,普通java工程沒有指定log4j.properties的路徑,那說明log4j的jar包一定有一個預設的路徑。另外,建議,log4j的配置放在第一個,因為後續加載其他元件就要開始使用日志記錄了
現在,你可以在多種類型的java工程中打出日志了,但都是控制台的日志,輸出内容也很有限,下面我們就來詳細介紹log4j.properties内容怎麼配置
接下來介紹的内容看起來獨立,其實互相關聯,并且很有規律,我們要輸出日志,首先得有日志對象(logger),那這些日志對象把日志輸出到哪裡呢,控制台還是檔案,這就要設定輸出位置(appender),輸出的格式與内容又是什麼樣的呢,這就要設定輸出樣式(layout),這些設定完,log4j的配置也就完了
在此之前,先介紹下log4j日志等級的概念,日志等級就是日志的重要程度,log4j日志分為7個等級:ALL、DEBUG、INFO、WARN、ERROR、FATAL、OFF,從左到右等級由低到高,分等級是為了設定日志輸出的門檻,隻有等級等于或高于這個門檻的日志才有機會輸出
日志執行個體,就是代碼裡執行個體化的Logger對象
這是全局logger的配置,LEVEL用來設定日志等級,appenderName定義日志輸出器,示例中的“console”就是一個日志輸出器
下面給出一個更清晰的例子,配置“com.demo.test”包下所有類中執行個體化的Logger對象
日志輸出器,指定logger的輸出位置
appender有5種選擇
每種appender都有若幹配置項,下面逐一介紹
ConsoleAppender(常用)
FileAppender
DailyRollingFileAppender(常用)
RollingFileAppender
指定logger輸出内容及格式
layout有4種選擇
layout也有配置項,下面具體介紹
HTMLLayout
PatternLayout(最常用的配置)
設定格式的參數說明如下
介紹完了log4j.properties内容,我們來配置一些常用的日志輸出吧
控制台console日志輸出器
檔案logFile日志輸出器
滾動檔案rollingFile日志輸出器
定期滾動檔案dailyFile日志輸出器
以上介紹的配置都是全局的,整個工程的代碼使用同一套配置,意味着所有的日志都輸出在了相同的地方,你無法直接了當的去看資料庫通路日志、使用者登入日志、記錄檔,它們都混在一起,是以,需要為包甚至是類配置單獨的日志輸出,下面給出一個例子,為“com.demo.test”包指定日志輸出器“test”,“com.demo.test”包下所有類的日志都将輸出到/log/test.log檔案
也可以讓同一個類輸出不同的日志,為達到這個目的,需要在這個類中執行個體化兩個logger
然後分别配置
slf4j是什麼?slf4j隻是定義了一組日志接口,但并未提供任何實作,既然這樣,為什麼要用slf4j呢?log4j不是已經滿足要求了嗎?
是的,log4j滿足了要求,但是,日志架構并不隻有log4j一個,你喜歡用log4j,有的人可能更喜歡logback,有的人甚至用jdk自帶的日志架構,這種情況下,如果你要依賴别人的jar,整個系統就用了兩個日志架構,如果你依賴10個jar,每個jar用的日志架構都不同,豈不是一個工程用了10個日志架構,那就亂了!
如果你的代碼使用slf4j的接口,具體日志實作架構你喜歡用log4j,其他人的代碼也用slf4j的接口,具體實作未知,那你依賴其他人jar包時,整個工程就隻會用到log4j日志架構,這是一種典型的門面模式應用,與jvm思想相同,我們面向slf4j寫日志代碼,slf4j處理具體日志實作架構之間的差異,正如我們面向jvm寫java代碼,jvm處理作業系統之間的差異,結果就是,一處編寫,到處運作。況且,現在越來越多的開源工具都在用slf4j了
那麼,怎麼用slf4j呢?
首先,得弄到slf4j的jar包,maven依賴如下,log4j配置過程完全不變
然後,弄到slf4j與log4j的關聯jar包,通過這個東西,将對slf4j接口的調用轉換為對log4j的調用,不同的日志實作架構,這個轉換工具不同
當然了,slf4j-log4j12這個包肯定依賴了slf4j和log4j,是以使用slf4j+log4j的組合隻要配置上面這一個依賴就夠了
最後,代碼裡聲明logger要改一下,原來使用log4j是這樣的
現在要改成這樣
依賴的Logger變了,而且,slf4j的api還能使用占位符,很友善
(完)
作者:淩承一
出處:http://www.cnblogs.com/ywlaker/
聲明:本文版權歸作者和部落格園共有,歡迎轉載,但轉載必須保留此段聲明,并在文章頁面明顯位置給出原文連結,否則作者将保留追究法律責任的權利。