logback發(fā)送告警郵件

在服務(wù)器程序運行時伴箩,如果出現(xiàn)一個錯誤日志,我們希望得到告警,方便及時處理整陌。 本文介紹如何使用logback中的SMTPAppender實現(xiàn)Error日志消息的發(fā)送.

申請郵箱開啟smtp

郵箱默認是禁用SMTP服務(wù)的,而且現(xiàn)在的主流郵箱甚至禁止使用郵箱密碼來使用SMTP服務(wù),而是需要另外使用一套授權(quán)碼作為密碼泌辫,這個也是為了提升安全

  • 開啟SMTP服務(wù)


    開啟SMTP服務(wù)
  • 網(wǎng)易郵箱設(shè)置授權(quán)碼


    網(wǎng)易郵箱授權(quán)碼
  • QQ郵箱設(shè)置授權(quán)碼


    QQ郵箱授權(quán)碼

網(wǎng)易郵箱可以自己設(shè)定授權(quán)碼随夸,QQ郵箱是由系統(tǒng)自動生成的一個授權(quán)碼

添加依賴

只需要添加額外的javax.mail,如果不是spring boot就還需要添加logback-classic

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>javax.mail</groupId>
        <artifactId>mail</artifactId>
        <version>1.4.7</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

日志配置文件

  • logback-spring.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <property name="commonPattern" value="[%d{yyyy-MM-dd HH:mm:ss.SSS}][%thread][%level][%class{0}:%line][%X{Trace-Id}]: %msg%n%rEx{full,
          java.lang.reflect.Method,
          sun.reflect,
          org.apache.catalina,
          org.springframework.aop,
          org.springframework.security,
          org.springframework.transaction,
          org.springframework.web,
          org.springframework.beans,
          org.springframework.cglib,
          net.sf.cglib,
          org.apache.tomcat.util,
          org.apache.coyote,
          ByCGLIB,
          BySpringCGLIB,
          com.google.common.cache.LocalCache$
        }"/>
    <appender name="EMAIL" class="ch.qos.logback.classic.net.SMTPAppender">
        <smtpHost>smtp.163.com</smtpHost>
        <smtpPort>465</smtpPort>
        <!--<STARTTLS>true</STARTTLS>-->
        <SSL>true</SSL>
        <asynchronousSending>false</asynchronousSending>
        <username>foo</username>
        <password>bar</password>
        <to>bar@qq.com</to>
        <from>foo@163.com</from>
        <subject>TESTING: %logger{20} - %m</subject>
        <layout class="ch.qos.logback.classic.PatternLayout">
            <pattern>${commonPattern}</pattern>
        </layout>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
    </appender>

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <!-- encoder 默認配置為PatternLayoutEncoder -->
        <encoder>
            <pattern>${commonPattern}</pattern>
        </encoder>
    </appender>

    <root level="DEBUG">
        <appender-ref ref="STDOUT"/>
    </root>

    <root level="WARN">
        <appender-ref ref="EMAIL"/>
    </root>

</configuration>

結(jié)果

SMTPAppender內(nèi)部使用了CyclicBuffer作為循環(huán)緩存保存日志記錄震放,當(dāng)遇到ERROR級別日志時宾毒,就會把CyclicBuffer中的所有日志作為一封郵件發(fā)送出去

告警郵件

注意事項

  • 日志中可能顯示了太多的非ERROR級別日志,可以增加配置
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
    <level>ERROR</level>
</filter>

常見問題

  • DynamicClassLoadingException: Failed to instantiate type ch.qos.logback.classic.net.SMTPAppender
  • java.lang.NoClassDefFoundError: javax/mail/internet/InternetAddress
  • javax.mail.AuthenticationFailedException: 550 User has no permission:一般是因為沒有開啟授權(quán)碼

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末殿遂,一起剝皮案震驚了整個濱河市诈铛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌墨礁,老刑警劉巖幢竹,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異饵溅,居然都是意外死亡妨退,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進店門蜕企,熙熙樓的掌柜王于貴愁眉苦臉地迎上來咬荷,“玉大人,你說我怎么就攤上這事轻掩⌒移梗” “怎么了?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵唇牧,是天一觀的道長罕扎。 經(jīng)常有香客問我,道長丐重,這世上最難降的妖魔是什么腔召? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮扮惦,結(jié)果婚禮上臀蛛,老公的妹妹穿的比我還像新娘。我一直安慰自己崖蜜,他們只是感情好浊仆,可當(dāng)我...
    茶點故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著豫领,像睡著了一般抡柿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上等恐,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天洲劣,我揣著相機與錄音备蚓,去河邊找鬼。 笑死闪檬,一個胖子當(dāng)著我的面吹牛星著,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播粗悯,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼同欠!你這毒婦竟也來了样傍?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤铺遂,失蹤者是張志新(化名)和其女友劉穎衫哥,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體襟锐,經(jīng)...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡撤逢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了粮坞。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚊荣。...
    茶點故事閱讀 38,650評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖莫杈,靈堂內(nèi)的尸體忽然破棺而出互例,到底是詐尸還是另有隱情,我是刑警寧澤筝闹,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布媳叨,位于F島的核電站,受9級特大地震影響关顷,放射性物質(zhì)發(fā)生泄漏糊秆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一议双、第九天 我趴在偏房一處隱蔽的房頂上張望痘番。 院中可真熱鬧,春花似錦聋伦、人聲如沸夫偶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽兵拢。三九已至,卻和暖如春逾礁,著一層夾襖步出監(jiān)牢的瞬間说铃,已是汗流浹背访惜。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留腻扇,地道東北人债热。 一個月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像幼苛,于是被迫代替她去往敵國和親窒篱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,527評論 2 349

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