自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

程序員因重復(fù)記錄日志撐爆ELK被辭退!

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

[[356982]]

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

下面看幾個(gè)常見導(dǎo)致該錯(cuò)誤的案例,大家引以為戒,避免被辭退。

1 logger配置繼承關(guān)系錯(cuò)誤

圖片

定義方法記錄debug、info、warn、error四種日志:

Logback配置

配置看沒啥問題,但執(zhí)行方法后明顯記錄重復(fù)了:

錯(cuò)因

CONSOLE這個(gè)Appender同時(shí)掛載到倆Logger,定義的,由于定義的繼承自,所以同一日志既會(huì)通過logger記錄,也會(huì)發(fā)送到root記錄,因此應(yīng)用包下日志出現(xiàn)重復(fù)。

如此配置的初衷是啥?

本想實(shí)現(xiàn)自定義logger配置,讓應(yīng)用內(nèi)日志暫時(shí)開啟DEBUG級(jí)別。

其實(shí),這無需重復(fù)掛載Appender,去掉下掛載的Appender即可

  1. <logger name="org.javaedge.logging" level="DEBUG"/> 

若自定義需把日志輸出到不同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ù)收集圖片

事故問責(zé)

一些公司使用自動(dòng)化ELK方案收集日志,日志會(huì)同時(shí)輸出到控制臺(tái)和文件,開發(fā)人員在本地測(cè)試不會(huì)關(guān)心文件中記錄的日志,而在測(cè)試和生產(chǎn)環(huán)境又因?yàn)殚_發(fā)人員沒有服務(wù)器訪問權(quán)限,所以原始日志文件中的重復(fù)問題難以發(fā)現(xiàn)。

到底為何重復(fù)?

ThresholdFilter源碼解析

圖片

  • 當(dāng)日志級(jí)別 ≥ 配置級(jí)別 返回NEUTRAL,繼續(xù)調(diào)用過濾器鏈上的下個(gè)過濾器
  • 否則返回DENY,直接拒絕記錄日志

該案例我們將 ThresholdFilter 置 WARN,因此可記錄WARN和ERROR級(jí)日志。

LevelFilter

用于比較日志級(jí)別,然后進(jìn)行相應(yīng)處理。

  • 若匹配就調(diào)用onMatch定義的處理方式:默認(rèn)交給下一個(gè)過濾器處理(AbstractMatcherFilter基類中定義的默認(rèn)值)
  • 否則調(diào)用onMismatch定義的處理方式:默認(rèn)也是交給下一個(gè)過濾器

和ThresholdFilter不同,LevelFilter僅配置level無法真正起作用。

由于未配置onMatch和onMismatch屬性,所以該過濾器失效,導(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ān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系 JavaEdge公眾號(hào)。

 

責(zé)任編輯:武曉燕 來源: JavaEdge
相關(guān)推薦

2018-09-12 14:58:54

程序員年紀(jì)大辭退

2021-12-28 10:19:26

程序員技能開發(fā)者

2019-02-14 10:04:34

程序員離職技術(shù)

2021-09-29 09:07:22

Docker 日志容器

2010-10-13 17:07:46

MySQL刪除重復(fù)記錄

2010-10-13 17:13:17

MySQL重復(fù)記錄

2010-09-25 16:17:25

SQL語句

2010-11-25 15:43:02

MYSQL查詢重復(fù)記錄

2014-08-29 11:09:44

程序員

2018-10-10 15:52:48

程序員代碼編程

2010-10-27 16:56:05

Oracle重復(fù)記錄

2010-11-23 14:26:02

MySQL刪除重復(fù)記錄

2010-10-27 16:49:23

Oracle刪除重復(fù)記

2015-03-18 09:51:45

2013-06-09 13:24:00

程序員Bug

2019-07-02 09:30:31

程序員勞動(dòng)陷阱

2009-05-08 08:34:58

中關(guān)村MSN辭退

2018-11-22 10:53:30

程序員技能開發(fā)者

2019-08-08 16:14:19

騰訊程序員辭退

2010-09-28 15:46:22

SQL刪除重復(fù)記錄
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)