Log4j2AsyncLoggerConfig導(dǎo)致線程Block

?AsyncLoggerConfig 導(dǎo)致線程 Block

通過(guò)監(jiān)控平臺(tái)查看線程監(jiān)控指標(biāo),從 Blocked 線程堆棧不難看出是和日志打印相關(guān)。分析異常線程堆棧 與(AsyncAppender 導(dǎo)致線程 Block)業(yè)務(wù)異常一樣划鸽。

解析異常堆棧

Log4j2 關(guān)于日志的幾個(gè)重要概念:

● ,日志配置標(biāo)簽靡狞,用于 XML 日志配置文件中褪那,對(duì)應(yīng) Log4j2 框架中的 LoggerConfig 類(lèi),同步分發(fā)日志事件到對(duì)應(yīng) Appender疚俱。

● 劝术,日志配置標(biāo)簽,用于 XML 日志配置文件中呆奕,對(duì)應(yīng) Log4j2框架中的?AsyncLoggerConfig?類(lèi)养晋,內(nèi)部使用 Disruptor 隊(duì)列異步分發(fā)日志事件到對(duì)應(yīng) Appender。

● Logger梁钾,同步日志類(lèi)绳泉,用于創(chuàng)建同步日志實(shí)例,同步調(diào)用 ReliabilityStrategy處理日志姆泻。

● AsyncLogger**零酪,異步日志類(lèi),用于創(chuàng)建異步日志實(shí)例**拇勃,內(nèi)部使用?Disruptor 隊(duì)列實(shí)現(xiàn)異步調(diào)用 ReliabilityStrategy 處理日志

? ? ? ?由于未配置 Log4jContextSelector 參數(shù)四苇,所以使用的是同步 Logger,即通過(guò) LoggerFactory.getLogger 方法獲取的是?Logger 類(lèi)實(shí)例而不是?AsyncLogger類(lèi)實(shí)例方咆,同時(shí)由于項(xiàng)目的 log4j2.xml 配置文件里配置了 標(biāo)簽月腋,所以其底層是 Logger 和 AsyncLoggerConfig 組合

? ? ? ? ? AsyncLoggerConfig 處理日志事件,其內(nèi)部使用 Disruptor隊(duì)列罗售,在生成隊(duì)列元素時(shí)辜窑,由 translator 來(lái)負(fù)責(zé)填充元素字段,并把填充后的元素放入 RingBuffer 中寨躁,于此同時(shí)穆碎,獨(dú)立的異步線程從 RingBuffer 中消費(fèi)事件,并調(diào)用配置在該 AsyncLoggerConfig 上的 Appender 處理日志請(qǐng)求职恳。

?AsyncLoggerConfig 提 供 了 帶 有 Disruptor 隊(duì) 列 實(shí) 現(xiàn) 的 代 理 類(lèi)?即 AsyncLoggerConfigDisruptor所禀, 在 日 志 事 件 進(jìn) 入 RingBuffer 時(shí), 由 于 項(xiàng) 目 使 用 的 是ReusableLogEventFactory放钦,所以由 MUTABLE_TRANSLATOR 負(fù)責(zé)初始化日志事件色徘,在此過(guò)程中會(huì)調(diào)用 getThrownProxy 方法創(chuàng)建 ThrowableProxy 實(shí)例,進(jìn)而在?ThrowableProxy 構(gòu)造函數(shù)內(nèi)部觸發(fā)解析操禀、加載異常堆棧類(lèi)褂策。

問(wèn)題小結(jié)

?Log4j2 打印異常日志時(shí)AsyncLoggerConfig 會(huì)初始化 Disruptor RingBuffer 日志元素字段颓屑,并進(jìn)一步觸發(fā)解析斤寂、加載異常堆棧類(lèi)JVM 通過(guò)生成字節(jié)碼的方式優(yōu)化反射調(diào)用性能揪惦,但該動(dòng)態(tài)生成的類(lèi)無(wú)法被 WebAppClassLoader 類(lèi)加載器加載遍搞,因此當(dāng)大量包含反射調(diào)用的異常堆棧被輸出到日志時(shí)會(huì)頻繁地觸發(fā)類(lèi)加載器腋,由于類(lèi)加載過(guò)程是?synchronized 同步加鎖的溪猿,且每次加載都需要讀取文件,速度較慢纫塌,從而導(dǎo)致線程 Block诊县。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市措左,隨后出現(xiàn)的幾起案子翎冲,更是在濱河造成了極大的恐慌,老刑警劉巖媳荒,帶你破解...
    沈念sama閱讀 206,968評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抗悍,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡钳枕,警方通過(guò)查閱死者的電腦和手機(jī)缴渊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)鱼炒,“玉大人衔沼,你說(shuō)我怎么就攤上這事。” “怎么了指蚁?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,220評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵菩佑,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我凝化,道長(zhǎng)稍坯,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,416評(píng)論 1 279
  • 正文 為了忘掉前任搓劫,我火速辦了婚禮瞧哟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘枪向。我一直安慰自己勤揩,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布秘蛔。 她就那樣靜靜地躺著陨亡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪深员。 梳的紋絲不亂的頭發(fā)上负蠕,一...
    開(kāi)封第一講書(shū)人閱讀 49,144評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音辨液,去河邊找鬼虐急。 笑死箱残,一個(gè)胖子當(dāng)著我的面吹牛滔迈,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播被辑,決...
    沈念sama閱讀 38,432評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼燎悍,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了盼理?” 一聲冷哼從身側(cè)響起谈山,我...
    開(kāi)封第一講書(shū)人閱讀 37,088評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎宏怔,沒(méi)想到半個(gè)月后奏路,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,586評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡臊诊,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評(píng)論 2 325
  • 正文 我和宋清朗相戀三年鸽粉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抓艳。...
    茶點(diǎn)故事閱讀 38,137評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡触机,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情儡首,我是刑警寧澤片任,帶...
    沈念sama閱讀 33,783評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站蔬胯,受9級(jí)特大地震影響对供,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜笔宿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評(píng)論 3 307
  • 文/蒙蒙 一犁钟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泼橘,春花似錦涝动、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,333評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至重归,卻和暖如春米愿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鼻吮。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,559評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工育苟, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人椎木。 一個(gè)月前我還...
    沈念sama閱讀 45,595評(píng)論 2 355
  • 正文 我出身青樓违柏,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親香椎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子漱竖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 前言 隨著業(yè)務(wù)的快速增長(zhǎng),日志導(dǎo)致的線程 Block 問(wèn)題愈發(fā)頻繁畜伐。比如調(diào)用后端 RPC 服務(wù)超時(shí)馍惹,導(dǎo)致調(diào)...
    淡若飄絮閱讀 1,166評(píng)論 0 0
  • 前言 隨著業(yè)務(wù)的快速增長(zhǎng),日志導(dǎo)致的線程 Block 問(wèn)題愈發(fā)頻繁玛界。比如調(diào)用后端 RPC 服務(wù)超時(shí)万矾,導(dǎo)致調(diào)...
    淡若飄絮閱讀 676評(píng)論 0 0
  • Configuration 將日志輸出插入到應(yīng)用程序代碼需要相當(dāng)多的計(jì)劃和努力。 觀察顯示慎框,大約4%的代碼專(zhuān)用于日...
    在下喵星人閱讀 12,599評(píng)論 0 1
  • 在項(xiàng)目開(kāi)發(fā)中良狈,都不可避免的使用到日志。沒(méi)有日志雖然不會(huì)影響項(xiàng)目的正確運(yùn)行鲤脏,但是沒(méi)有日志的項(xiàng)目可以說(shuō)是不完整的们颜。日志...
    JourWon閱讀 3,869評(píng)論 0 5
  • 這是在公司內(nèi)部的一次升級(jí)實(shí)踐吕朵,刪除了很多隱私的內(nèi)容,所以可能不是很完整窥突。 1努溃、背景 在任何系統(tǒng)中,日志都是非常重要...
    高廣超閱讀 10,278評(píng)論 2 35