新聞中心
由于日志配置繁雜,很多同學(xué)喜歡直接cv其他項(xiàng)目或網(wǎng)上博客的配置文件,而不仔細(xì)研究每個(gè)配置項(xiàng)。最常見(jiàn)的就是重復(fù)記錄日志,這不但給查看和統(tǒng)計(jì)帶來(lái)不必要麻煩,還會(huì)增加磁盤(pán)和日志收集系統(tǒng)負(fù)擔(dān)。

成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括巴南網(wǎng)站建設(shè)、巴南網(wǎng)站制作、巴南網(wǎng)頁(yè)制作以及巴南網(wǎng)絡(luò)營(yíng)銷(xiāo)策劃等。多年來(lái),我們專(zhuān)注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,巴南網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶(hù)以成都為中心已經(jīng)輻射到巴南省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶(hù)的支持與信任!
下面看幾個(gè)常見(jiàn)導(dǎo)致該錯(cuò)誤的案例,大家引以為戒,避免被辭退。
1 logger配置繼承關(guān)系錯(cuò)誤
圖片
定義方法記錄debug、info、warn、error四種日志:
Logback配置
配置看沒(méi)啥問(wèn)題,但執(zhí)行方法后明顯記錄重復(fù)了:
錯(cuò)因
CONSOLE這個(gè)Appender同時(shí)掛載到倆Logger,定義的 和 ,由于定義的 繼承自 ,所以同一日志既會(huì)通過(guò)logger記錄,也會(huì)發(fā)送到root記錄,因此應(yīng)用包下日志出現(xiàn)重復(fù)。
如此配置的初衷是啥?
本想實(shí)現(xiàn)自定義logger配置,讓?xiě)?yīng)用內(nèi)日志暫時(shí)開(kāi)啟DEBUG級(jí)別。
其實(shí),這無(wú)需重復(fù)掛載Appender,去掉 下掛載的Appender即可
若自定義 需把日志輸出到不同Appender,比如
- 應(yīng)用日志輸出到文件app.log
- 其他框架日志輸出到控制臺(tái)
可設(shè)置 的additivity屬性為false,就不會(huì)繼承 Appender
2 配置LevelFilter錯(cuò)誤
記錄日志到控制臺(tái)時(shí),將日志按級(jí)別記錄到倆文件
執(zhí)行結(jié)果
info.log 文件包含INFO、WARN和ERROR三級(jí)日志,不符預(yù)期
error.log包含WARN和ERROR倆級(jí)別日志,導(dǎo)致日志重復(fù)收集圖片
事故問(wèn)責(zé)
一些公司使用自動(dòng)化ELK方案收集日志,日志會(huì)同時(shí)輸出到控制臺(tái)和文件,開(kāi)發(fā)人員在本地測(cè)試不會(huì)關(guān)心文件中記錄的日志,而在測(cè)試和生產(chǎn)環(huán)境又因?yàn)殚_(kāi)發(fā)人員沒(méi)有服務(wù)器訪問(wèn)權(quán)限,所以原始日志文件中的重復(fù)問(wèn)題難以發(fā)現(xiàn)。
到底為何重復(fù)?
ThresholdFilter源碼解析
圖片
- 當(dāng)日志級(jí)別 ≥ 配置級(jí)別 返回NEUTRAL,繼續(xù)調(diào)用過(guò)濾器鏈上的下個(gè)過(guò)濾器
- 否則返回DENY,直接拒絕記錄日志
該案例我們將 ThresholdFilter 置 WARN,因此可記錄WARN和ERROR級(jí)日志。
LevelFilter
用于比較日志級(jí)別,然后進(jìn)行相應(yīng)處理。
- 若匹配就調(diào)用onMatch定義的處理方式:默認(rèn)交給下一個(gè)過(guò)濾器處理(AbstractMatcherFilter基類(lèi)中定義的默認(rèn)值)
- 否則調(diào)用onMismatch定義的處理方式:默認(rèn)也是交給下一個(gè)過(guò)濾器
和ThresholdFilter不同,LevelFilter僅配置level無(wú)法真正起作用。
由于未配置onMatch和onMismatch屬性,所以該過(guò)濾器失效,導(dǎo)致INFO以上級(jí)別日志都記錄了。
修正
配置LevelFilter的onMatch屬性為ACCEPT,表示接收INFO級(jí)別的日志;配置onMismatch屬性為DENY,表示除了INFO級(jí)別都不記錄:
如此,_info.log文件只會(huì)有INFO級(jí)日志,不會(huì)再出現(xiàn)日志重復(fù)。
本文轉(zhuǎn)載自微信公眾號(hào)「 JavaEdge」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系 JavaEdge公眾號(hào)。
新聞名稱(chēng):程序員因重復(fù)記錄日志撐爆ELK被辭退!
URL網(wǎng)址:http://www.dlmjj.cn/article/cogjcoe.html


咨詢(xún)
建站咨詢(xún)
