欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

log4j 詳解異步日志的配置和測(cè)試

 更新時(shí)間:2017年01月20日 14:32:46   投稿:lqh  
這篇文章主要介紹了 log4j 詳解異步日志的配置和測(cè)試的相關(guān)資料,需要的朋友可以參考下

 log4j 詳解異步日志的配置和測(cè)試

日志可以幫助我們分析故障原因,做些數(shù)據(jù)挖掘的工作。最簡(jiǎn)單的日志方法,就是自己寫個(gè)寫文件的方法,在需要打日志的時(shí)候調(diào)用下,但是這顯然不可能在實(shí)際工程上用。還有個(gè)問(wèn)題,就是頻繁地打日志,會(huì)增加磁盤I/O,使得系統(tǒng)性能下降。這里用log4j這個(gè)庫(kù)來(lái)部署一個(gè)含有日志管理的輕量級(jí)的系統(tǒng),主要支持日志的異步寫和等級(jí)分類的功能,完成最低限度的日志需求。

首先,我們建立一個(gè)Maven工程,并且在pom.xml文件里面引入log4j的依賴:

<dependency> 
  <groupId>org.slf4j</groupId> 
  <artifactId>slf4j-log4j12</artifactId> 
  <version>1.7.2</version> 
</dependency> 


接著,我們?cè)趕rc/main/resources路徑下面創(chuàng)建一個(gè)配置文件:log4j.xml


其實(shí)xml配置文件的內(nèi)容是至關(guān)重要的,里面必須定義日志的等級(jí)、是否異步等屬性。這里我通過(guò)截圖來(lái)簡(jiǎn)單說(shuō)明幾個(gè)關(guān)鍵點(diǎn)。完整的配置文件會(huì)隨這篇博客一起上傳。


這里關(guān)于日志等級(jí)需要多解釋一下,這里的日志等級(jí)默認(rèn)是debug:

所以如果不像上圖中利用日志過(guò)濾器來(lái)定義日志等級(jí),那么最后ERROR日志的會(huì)寫到INFO日志的文件里,導(dǎo)致日志管理混亂。所以需要來(lái)設(shè)置這個(gè)日志等級(jí)的問(wèn)題。


這張圖需要解釋的不多,主要是異步日志的配置。

那么到這里,日志的配置基本就好了。而想要在程序里面引用直接就寫成:

然后調(diào)用log.info,log.error等方法就可以寫日志了。注意我們?cè)O(shè)了2KB的大小,因此日志會(huì)累計(jì)到2KB再去寫。所以并不是實(shí)時(shí)的,但這樣可以減少頻繁的磁盤I/O,在壓測(cè)的時(shí)候可以避免由于I/O所帶來(lái)的CPU的損耗。

接著我們寫一段簡(jiǎn)單的測(cè)試程序來(lái)驗(yàn)證我們的配置是否正確。


這段代碼的功能很簡(jiǎn)單:迭代計(jì)數(shù)到10W,然后將10的倍數(shù)寫到error日志里,非10的倍數(shù)寫到info日志里面。運(yùn)行該程序,就會(huì)在相應(yīng)的文件里打印出響應(yīng)的結(jié)果。具體的日志結(jié)果如下圖:


需要注意的是,當(dāng)天的日志不會(huì)馬上加上日期,隔了一天后會(huì)顯示日期(如何馬上顯示當(dāng)天的日期,樓主還沒(méi)搞定)。info和error日志中的內(nèi)容如下:


可見(jiàn),通過(guò)我們之前之前的配置,我們可以按照我們的意思來(lái)正確地打印日志。ok,就先寫到這里。

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • 基于Java實(shí)現(xiàn)的一層簡(jiǎn)單人工神經(jīng)網(wǎng)絡(luò)算法示例

    基于Java實(shí)現(xiàn)的一層簡(jiǎn)單人工神經(jīng)網(wǎng)絡(luò)算法示例

    這篇文章主要介紹了基于Java實(shí)現(xiàn)的一層簡(jiǎn)單人工神經(jīng)網(wǎng)絡(luò)算法,結(jié)合實(shí)例形式分析了java實(shí)現(xiàn)人工神經(jīng)網(wǎng)絡(luò)的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-12-12
  • Java多線程 樂(lè)觀鎖和CAS機(jī)制詳細(xì)

    Java多線程 樂(lè)觀鎖和CAS機(jī)制詳細(xì)

    這篇文章主要介紹了Java多線程 樂(lè)觀鎖和CAS機(jī)制,樂(lè)觀鎖是對(duì)于數(shù)據(jù)沖突保持一種樂(lè)觀態(tài)度,操作數(shù)據(jù)時(shí)不會(huì)對(duì)操作的數(shù)據(jù)進(jìn)行加鎖,需要的朋友可以參考下
    2021-10-10
  • 使用SpringMVC的@Validated注解驗(yàn)證的實(shí)現(xiàn)

    使用SpringMVC的@Validated注解驗(yàn)證的實(shí)現(xiàn)

    這篇文章主要介紹了使用SpringMVC的@Validated注解驗(yàn)證的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • java中棧和隊(duì)列的實(shí)現(xiàn)和API的用法(詳解)

    java中棧和隊(duì)列的實(shí)現(xiàn)和API的用法(詳解)

    下面小編就為大家?guī)?lái)一篇java中棧和隊(duì)列的實(shí)現(xiàn)和API的用法(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • SpringBoot切面實(shí)現(xiàn)token權(quán)限校驗(yàn)詳解

    SpringBoot切面實(shí)現(xiàn)token權(quán)限校驗(yàn)詳解

    這篇文章主要介紹了SpringBoot切面實(shí)現(xiàn)token權(quán)限校驗(yàn)詳解,要實(shí)現(xiàn)權(quán)限校驗(yàn),首先數(shù)據(jù)表和實(shí)體類上需要有權(quán)限字段,我的表中permission和gender是通過(guò)外鍵約束permission表和gender表實(shí)現(xiàn)枚舉的,因?yàn)榭赏卣剐愿?需要的朋友可以參考下
    2024-01-01
  • springboot+redis實(shí)現(xiàn)簡(jiǎn)單的熱搜功能

    springboot+redis實(shí)現(xiàn)簡(jiǎn)單的熱搜功能

    這篇文章主要介紹了springboot+redis實(shí)現(xiàn)一個(gè)簡(jiǎn)單的熱搜功能,通過(guò)代碼介紹了過(guò)濾不雅文字的過(guò)濾器,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Java遠(yuǎn)程連接Linux服務(wù)器并執(zhí)行命令及上傳文件功能

    Java遠(yuǎn)程連接Linux服務(wù)器并執(zhí)行命令及上傳文件功能

    這篇文章主要介紹了Java遠(yuǎn)程連接Linux服務(wù)器并執(zhí)行命令及上傳文件功能,本文是小編整理的代碼筆記,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05
  • Java控制語(yǔ)句之if、switch語(yǔ)句

    Java控制語(yǔ)句之if、switch語(yǔ)句

    這篇文章主要介紹了Java控制語(yǔ)句之if、switch語(yǔ)句的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • 淺談spring DI 依賴注入方式和區(qū)別

    淺談spring DI 依賴注入方式和區(qū)別

    Spring框架對(duì)Java開發(fā)的重要性不言而喻,本文主要介紹了spring DI 依賴注入方式和區(qū)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 解析java中super的用法分析

    解析java中super的用法分析

    本篇文章是對(duì)java中super的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05

最新評(píng)論