JHipster一知半解- 3.2Logback-日志切點(diǎn)

回目錄:JHipster一知半解

Logback配置

Logback是由log4j創(chuàng)始人設(shè)計(jì)的另一個(gè)開源日志組件,是log4j的一個(gè)改良版本癞尚。
主要分為logback-core粗截,logback-classic惋耙,logback-access三個(gè)模塊

1. 引入與生效過程

作為spring-boot項(xiàng)目,Pom.xml中增加了對spring-boot-starter-logging的依賴熊昌。

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-logging</artifactId>
</dependency>

在spring-boot-starter-logging*.jar中绽榛,也就說引入了logback的幾個(gè)依賴包

<dependencies>
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>jcl-over-slf4j</artifactId>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>jul-to-slf4j</artifactId>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>log4j-over-slf4j</artifactId>
        </dependency>
    </dependencies>

那么在spring-boot的啟動中,slf4j的LoggerFactory就能自動識別到用了logback進(jìn)行日志初始化(具體在findPossibleStaticLoggerBinderPathSet())函數(shù)中婿屹,用ClassLoader動態(tài)查找LOGGER_BINDER路徑灭美,從而發(fā)現(xiàn)logback,有興趣可以自行斷點(diǎn)查看昂利。

2. 配置

spring-boot本身對幾個(gè)主流的日志系統(tǒng)都做了基礎(chǔ)的配置届腐,也就是說,即使什么也不做蜂奸,只需要上面引入的strater-logging犁苏,也能獲得基本的配置能力。
具體代碼在org.springframework.boot.logging.LoggingApplicationListener中窝撵,這個(gè)監(jiān)聽器傀顾,監(jiān)聽到應(yīng)用程序啟動(main()函數(shù)里面的run()方法),調(diào)用

this.loggingSystem.beforeInitialize()碌奉;

實(shí)際上是org.springframework.boot.logging.logback.LogbackLoggingSystem就進(jìn)行了對應(yīng)的初始化工作短曾,這里配置了logback默認(rèn)的配置文件base.xml,另外Spring Boot 提供了兩個(gè)輸出端的配置文件console-appender.xml和file-appender.xml赐劣,base.xml引用了這兩個(gè)配置文件嫉拐。

當(dāng)然JHipster不會僅僅采用默認(rèn)的配置,在src/main/resources目錄里面魁兼,定義了logback-spring.xml作為項(xiàng)目logback的配置婉徘。

2.1. 首先,include了默認(rèn)的base.xml咐汞,作為基礎(chǔ)盖呼。

2.2. 由于默認(rèn)的root level="INFO",那么這里面就針對需要修改的類化撕,進(jìn)行對應(yīng)等級調(diào)整几晤,如com.ryantenney設(shè)置為WARN,io.undertow.websockets.jsr就設(shè)置為ERROR植阴,org.apache.catalina.startup.DigesterFactory設(shè)置為OFF

2.3. 默認(rèn)生成的appender蟹瘾,只配置生效了CONSOLE圾浅,但同時(shí)也很貼心地寫好并注釋了FILE的appender,需要的話憾朴,取消注釋狸捕,即可生效。(微服務(wù)架構(gòu)目標(biāo)是動態(tài)伸縮众雷,如果還是每個(gè)服務(wù)都保存自己的日志文件灸拍,有點(diǎn)低效,推薦整合ELK砾省,統(tǒng)一收集日志信息)

3. aop.logging的LoggingAspect

這個(gè)配置是基于spring的AOP株搔,對需要debug的類,進(jìn)行額外的日志打印功能纯蛾。

3.1. 構(gòu)造函數(shù)

public LoggingAspect(Environment env) {
        this.env = env;
    }

用來把spring啟動的環(huán)境變量傳遞進(jìn)來,可以在logAfterThrowing()看到纵隔,根據(jù)生效的profile不同翻诉,打印的日志也是不同的。

3.2. 切點(diǎn)
springBeanPointcut()是從類注解的角度捌刮,有加上@Repository碰煌,@Service,@RestController的绅作。
applicationPackagePointcut()是從類位置的角度芦圾,位于項(xiàng)目中repository,service俄认,web.rest包中的个少。

3.3. 統(tǒng)一的異常打印logAfterThrowing
如果業(yè)務(wù)處理出現(xiàn)異常,這里統(tǒng)一捕捉眯杏,并根據(jù)激活的profile不同夜焦,日志格式有所不同

3.4 統(tǒng)一的日志登記logAround
針對需要擴(kuò)展的業(yè)務(wù)處理部分,如果log.isDebugEnabled()岂贩,則在方法的處理之前辨嗽,和之后都打印出對應(yīng)的日志九孩,方便調(diào)試。

4. 動態(tài)改變log日志等級web.rest.LogsResource

spring-boot是1.5版本后才在actuator增加了loggers端點(diǎn)了,JHipster在spring還沒有此功能前就自定義了一個(gè)rest端點(diǎn)完成對應(yīng)的工作体箕。
代碼相對簡單,兩個(gè)方法继阻,一個(gè)get办龄,一個(gè)put。都是獲取LoggerContext部念,然后進(jìn)行相應(yīng)的操作弃酌。

web.rest.vm氨菇。LoggerVM
JHipster使用了VM作為前后端傳遞對象視圖模型,LoggerVM只有2個(gè)屬性妓湘,name和level查蓉,這樣就簡化了前后端的數(shù)據(jù)傳遞,畢竟我們的目標(biāo)只是顯示和修改日志的等級設(shè)置榜贴,傳遞整個(gè)Logger對象顯然不適合豌研。

資源和書籍推薦

logback的使用和logback.xml詳解 (https://www.cnblogs.com/warking/p/5710303.html)

http://blog.csdn.net/sun_t89/article/details/52130839

https://springframework.guru/using-logback-spring-boot/

Logback用戶手冊中文版(鏈接:http://pan.baidu.com/s/1hsH0JaO 密碼:pq1z)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市唬党,隨后出現(xiàn)的幾起案子鹃共,更是在濱河造成了極大的恐慌,老刑警劉巖驶拱,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件霜浴,死亡現(xiàn)場離奇詭異,居然都是意外死亡蓝纲,警方通過查閱死者的電腦和手機(jī)阴孟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來税迷,“玉大人永丝,你說我怎么就攤上這事〖” “怎么了慕嚷?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長毕泌。 經(jīng)常有香客問我喝检,道長,這世上最難降的妖魔是什么懈词? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任蛇耀,我火速辦了婚禮,結(jié)果婚禮上坎弯,老公的妹妹穿的比我還像新娘纺涤。我一直安慰自己,他們只是感情好抠忘,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布撩炊。 她就那樣靜靜地躺著,像睡著了一般崎脉。 火紅的嫁衣襯著肌膚如雪拧咳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天囚灼,我揣著相機(jī)與錄音骆膝,去河邊找鬼祭衩。 笑死,一個(gè)胖子當(dāng)著我的面吹牛阅签,可吹牛的內(nèi)容都是我干的掐暮。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼政钟,長吁一口氣:“原來是場噩夢啊……” “哼路克!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起养交,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤精算,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后碎连,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體灰羽,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年鱼辙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了谦趣。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡座每,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出摘悴,到底是詐尸還是另有隱情峭梳,我是刑警寧澤,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布蹂喻,位于F島的核電站葱椭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏口四。R本人自食惡果不足惜孵运,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蔓彩。 院中可真熱鬧治笨,春花似錦、人聲如沸赤嚼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽更卒。三九已至等孵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蹂空,已是汗流浹背俯萌。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工果录, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人咐熙。 一個(gè)月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓弱恒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親糖声。 傳聞我的和親對象是個(gè)殘疾皇子斤彼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評論 2 355

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