log4j 詳解異步日志的配置和測試
日志可以幫助我們分析故障原因,做些數(shù)據(jù)挖掘的工作。最簡單的日志方法,就是自己寫個寫文件的方法,在需要打日志的時候調(diào)用下,但是這顯然不可能在實(shí)際工程上用。還有個問題,就是頻繁地打日志,會增加磁盤I/O,使得系統(tǒng)性能下降。這里用log4j這個庫來部署一個含有日志管理的輕量級的系統(tǒng),主要支持日志的異步寫和等級分類的功能,完成最低限度的日志需求。
首先,我們建立一個Maven工程,并且在pom.xml文件里面引入log4j的依賴:
1
2
3
4
5
|
< dependency > < groupId >org.slf4j</ groupId > < artifactId >slf4j-log4j12</ artifactId > < version >1.7.2</ version > </ dependency > |
接著,我們在src/main/resources路徑下面創(chuàng)建一個配置文件:log4j.xml
其實(shí)xml配置文件的內(nèi)容是至關(guān)重要的,里面必須定義日志的等級、是否異步等屬性。這里我通過截圖來簡單說明幾個關(guān)鍵點(diǎn)。完整的配置文件會隨這篇博客一起上傳。
這里關(guān)于日志等級需要多解釋一下,這里的日志等級默認(rèn)是debug:
所以如果不像上圖中利用日志過濾器來定義日志等級,那么最后ERROR日志的會寫到INFO日志的文件里,導(dǎo)致日志管理混亂。所以需要來設(shè)置這個日志等級的問題。
這張圖需要解釋的不多,主要是異步日志的配置。
那么到這里,日志的配置基本就好了。而想要在程序里面引用直接就寫成:
然后調(diào)用log.info,log.error等方法就可以寫日志了。注意我們設(shè)了2KB的大小,因此日志會累計到2KB再去寫。所以并不是實(shí)時的,但這樣可以減少頻繁的磁盤I/O,在壓測的時候可以避免由于I/O所帶來的CPU的損耗。
接著我們寫一段簡單的測試程序來驗證我們的配置是否正確。
這段代碼的功能很簡單:迭代計數(shù)到10W,然后將10的倍數(shù)寫到error日志里,非10的倍數(shù)寫到info日志里面。運(yùn)行該程序,就會在相應(yīng)的文件里打印出響應(yīng)的結(jié)果。具體的日志結(jié)果如下圖:
需要注意的是,當(dāng)天的日志不會馬上加上日期,隔了一天后會顯示日期(如何馬上顯示當(dāng)天的日期,樓主還沒搞定)。info和error日志中的內(nèi)容如下:
可見,通過我們之前之前的配置,我們可以按照我們的意思來正確地打印日志。ok,就先寫到這里。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/wangongxi/article/details/49686883