Log4j的郵件發送類SMTPAppender改造

在開發過程中,我們有時需要將重要的錯誤日志通過郵件發送給相關的責任人,這樣能即時發現錯誤,即時解決。如使用Log4J,一般會做如下配置:

log4j.rootLogger = debug,mail

# 發送日志到指定郵件
log4j.appender.mail=org.apache.log4j.net.SMTPAppender
log4j.appender.mail.Threshold=INFO
log4j.appender.mail.BufferSize=10
log4j.appender.mail.From=from@qq.com
log4j.appender.mail.To=to@163.com
log4j.appender.mail.SMTPHost=smtp.qq.com
#發送郵件箱的用戶
log4j.appender.mail.SMTPUsername=from@qq.com
#郵箱的授權碼
log4j.appender.mail.SMTPPassword=

但是我在使用過程中發現標準的org.apache.log4j.net.SMTPAppender有如下幾個問題。

  1. 同步發送郵件。這樣會阻塞業務正常進行(比如等待一個SQL查詢,需要等待郵件發送后才顯示結果,顯然不能忍受)

解決辦法: 使用線程池的方式,將發送郵件包裝成Runnable任務,送到線程池中執行。同步隊列我選擇的是設置了固定大小的LinkedBlockingQueue,設置固定大小是因為需要發郵件的重要日志不是太多,二是不能因為郵件任務占用了太多的內存;選擇LinkedBlockingQueue,是因為LinkedBlockingQueue讀寫鎖分離,可以邊添加任務,邊發送郵件;核心線程數和最大線程數,可以根據業務量和CPU核數設定。

  1. 緩存大小bufferSize(日志事件的個數)只是設置緩存大小,并不能等到緩存滿時才發送(其實是只要有發生ERROR級別及以上的的事件時就將緩存中保存的所有滿足threshold級別的日志都發送,在發送之前緩存滿時會從頭開始,新的日志覆蓋舊的)

解決辦法: 去掉默認實現類CyclicBuffer,改成同步隊列;因為CyclicBuffer線程不安全,添加日志和獲取日志并不是同一個線程,所以采用了線程安全的同步隊列,而且還需要實現當同步隊列中日志快滿時將觸發發送郵件;所以需要自定義同步隊列,加上一個閥值factor,當同步隊列中的日志個數達到bufferSize*factor時就發送郵件,這樣可以預留一部分空間存放后添加進來的日志;同步隊列我選擇的是 LinkedBlockingQueue,可以邊添加日志,邊讀取日志,吞吐量比較大。目前發送郵件觸發的條件是:發生了 ERRORERROR以上級別 的錯誤時發送郵件,改成當緩存同步隊列中元素個數大于或等于 bufferSize*factor 時,觸發回調函數,啟動發送郵件任務。

改造步驟:
1. 定義回調接口AlertWillBeFull
2. 自定義同步隊列 AlertLinkedBlockingQueue ,繼承 LinkedBlockingQueue ,添加成員變量factor及回調接口,在所有添加動作之前進行判斷是否達到閥值。
3. 去掉SMTPAppender類中的實現類DefaultEvaluator及所有調用它的地方
4. 在創建緩存同步隊列時,傳入回調對象,等待同步隊列調用
5. 添加日志到緩存同步隊列和從緩存同步隊列讀取日志分別使用offer和poll方法,不阻塞線程也不拋異常,以免影響實際業務進行,而且少少量日志影響也不大。

  1. 發送的日志比較雜亂,需要排除某些包下的日志(比如有些不重要的日志,或者只想看某些包下的日志

解決方法:添加成員變量excludePackagesincludePackages,修改checkEntryConditions方法邏輯

這樣就能在log4j.properties配置文件中配置緩存大小,以及添加排除或只關心的記錄日志的包,也可以添加多個發送郵件的配置,將不同包下的日志發送給不同的責任人。

最終配置如下:

log4j.rootLogger = debug,mail

# 發送日志到指定郵件
log4j.appender.mail=org.apache.log4j.net.SMTPAppender
#排除的包(多個包,以英文逗號隔開)
#log4j.appender.mail.excludePackage=com.alibaba.druid
#僅關心的包,一般excludePackage與includePackage任選一即可,多個包以英文逗號隔開
log4j.appender.mail.includePackage=cn.yang.practise.service,cn.yang.practise.controller,com.alibaba.druid
log4j.appender.mail.Threshold=INFO
log4j.appender.mail.BufferSize=16
log4j.appender.mail.From=from@qq.com
log4j.appender.mail.To=to@163.com
log4j.appender.mail.SMTPHost=smtp.qq.com
#發送郵件箱的用戶
log4j.appender.mail.SMTPUsername=from@qq.com
#郵箱的授權碼
log4j.appender.mail.SMTPPassword=

改造后完整后的org.apache.log4j.net.SMTPAppenderAlertLinkedBlockingQueue

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,443評論 6 532
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,530評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,407評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,981評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,759評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,204評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,263評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,415評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,955評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,650評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,892評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,675評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,967評論 2 374

推薦閱讀更多精彩內容

  • 本文是我自己在秋招復習時的讀書筆記,整理的知識點,也是為了防止忘記,尊重勞動成果,轉載注明出處哦!如果你也喜歡,那...
    波波波先森閱讀 11,290評論 4 56
  • 在應用程序中添加日志記錄總的來說基于三個目的:監視代碼中變量的變化情況,周期性的記錄到文件中供其他應用進行統計分析...
    時待吾閱讀 5,067評論 1 13
  • 在應用程序中添加日志記錄總的來說基于三個目的:監視代碼中變量的變化情況,周期性的記錄到文件中供其他應用進行統計分析...
    時待吾閱讀 5,009評論 0 6
  • 1.ios高性能編程 (1).內層 最小的內層平均值和峰值(2).耗電量 高效的算法和數據結構(3).初始化時...
    歐辰_OSR閱讀 29,478評論 8 265
  • 做對孩子有用的事情 做對孩子有用的事情 最近,看了一篇文章,題目是《你的付出99%是沒用...
    夢與葉櫻閱讀 300評論 1 0