【SpringBoot專(zhuān)題】Java平臺(tái)下日志的那些事

前言

《【SpringBoot專(zhuān)題】快速體驗(yàn)》

《【SpringBoot專(zhuān)題】多環(huán)境配置及swagger》

本篇是【SpringBoot專(zhuān)題】系列的第三篇,將介紹SpringBoot對(duì)日志的支持淫半,講解Java平臺(tái)下日志的那些事,徹底揭開(kāi)日志框架在使用過(guò)程中的那些坑~


日志框架漫談

Java平臺(tái)下存在很多日志框架矢赁,比如JUL(java.util.logging)排嫌,JCL(Apache Commons Logging)对粪,Log4j,Log4j2箱靴,Logback谱姓,SLF4j,jboss-logging等刨晴。

java平臺(tái)下日志框架的發(fā)展屉来,經(jīng)歷了具體的日志實(shí)現(xiàn),后來(lái)發(fā)展為日志門(mén)面+日志實(shí)現(xiàn)狈癞。

java日志

當(dāng)我們?cè)陂_(kāi)發(fā)的時(shí)候茄靠,應(yīng)該使用日志門(mén)面提供的api,而不是直接使用具體的日志實(shí)現(xiàn)蝶桶。

打個(gè)比方慨绳,如果我們使用slf4j+log4j這套組合,那么配置提供log4j的配置(比如log4j.xml),使用slf4j提供的日志api即可脐雪;也就是說(shuō)厌小,每個(gè)日志實(shí)現(xiàn)框架都有自己的日志配置文件,即便使用日志門(mén)面后战秋,依然要提供各自的配置文件璧亚。(也就是日志門(mén)面只是實(shí)現(xiàn)了api的適配,而沒(méi)有進(jìn)行日志配置的統(tǒng)一規(guī)范)

當(dāng)前最流行的日志門(mén)面是slf4j了脂信,我們就以這個(gè)為例來(lái)具體分析下癣蟋,主要進(jìn)行2點(diǎn)分析:

第一:slf4j是如何對(duì)各個(gè)日志實(shí)現(xiàn)進(jìn)行適配?

第二:如何在項(xiàng)目中進(jìn)行日志的統(tǒng)一使用狰闪?

slf4j+logback
slf4j+log4j

上面2個(gè)圖分別是:slf4j+logback和slf4j+log4j這2套日志組合的方式圖解說(shuō)明疯搅。

首先,我們來(lái)說(shuō)第一個(gè)問(wèn)題埋泵,sl4j如何和其他日志實(shí)現(xiàn)框架適配的問(wèn)題幔欧。

很簡(jiǎn)單,我們只需要看圖中的左側(cè)部分丽声,提供相應(yīng)的jar即可(有的除了具體的日志實(shí)現(xiàn)外琐馆,還需要提供額外的適配jar包)。

其次恒序,我們要注意一個(gè)問(wèn)題,由于在項(xiàng)目開(kāi)發(fā)中谁撼,不可避免需要引入其他依賴(lài)歧胁,比如Spring默認(rèn)使用的是commons-logging(即JCL),而Hibernate默認(rèn)使用的是jboss-logging,那么問(wèn)題就來(lái)了厉碟,我們?nèi)绾谓y(tǒng)一日志記錄的方式喊巍?

上圖中的右側(cè)部分就揭示了方法,打個(gè)比方箍鼓,如果我們依賴(lài)Spring崭参,雖然Spring默認(rèn)使用的是JCL,要想在項(xiàng)目中統(tǒng)一使用slf4j+logback的話(huà),很簡(jiǎn)單款咖,我們先排除掉 JCL的依賴(lài)何暮,然后再引入jcl-over-slf4j.jar的依賴(lài)即可。(其實(shí)就是在偷梁換柱铐殃,jcl-over-slf4j.jar和JCL在包名/類(lèi)名/方法名上完全一致海洼,只不過(guò)jcl-over-slf4j在內(nèi)部調(diào)用的是slf4j的api而已,這樣既可以避免Spring報(bào)錯(cuò)富腊,又可以將Spring日志記錄方式加以改變;捣辍)


看SpringBoot如何對(duì)日志進(jìn)行統(tǒng)一處理

SpringBoot能自動(dòng)適配所有的日志,而且底層使用的是slf4j+logback的方式記錄日志,引入其他框架的時(shí)候是整,只需要把這個(gè)框架依賴(lài)的日志框架排除掉即可肖揣。

SpringBoot很聰明,它已經(jīng)把一些日志適配依賴(lài)都引入進(jìn)來(lái)了浮入,下面我們具體分析龙优。

springboot日志依賴(lài)

我想通過(guò)上圖的日志依賴(lài)關(guān)系,你就會(huì)明白springboot的良苦用心了舵盈!

上文說(shuō)過(guò)Spring默認(rèn)的日志依賴(lài)是JCL陋率,而SpringBoot肯定是依賴(lài)Spring的,根據(jù)上文理論秽晚,自然是需要排除掉JCL的依賴(lài)的瓦糟,我們來(lái)看下面的:

springboot依賴(lài)spring
spring已經(jīng)排除掉JCL依賴(lài)


SpringBoot日志使用

關(guān)于SpringBoot日志的使用上,主要指出下面幾點(diǎn):

第一:全局的一些常用配置赴蝇,如格式/路徑/級(jí)別

第二:使用@Slf4j來(lái)進(jìn)行日志處理

第三:日志的profile功能

第四:切換日志框架

在application.properties中進(jìn)行日志配置

指定日志配置文件路徑 logging.config=classpath:logback.xml?

采用logging.path的方式指定日志路徑

指定日志級(jí)別菩浙,要么在application.properties中直接指定:

logging.level.x.y.z=info

要么在logback.xml中配置。

關(guān)于日志的具體配置句伶,這里不詳細(xì)介紹劲蜻,網(wǎng)上有很多資料大家可以參考。

日志的具體使用考余,相信大家很清楚先嬉,基本上就是先得到log對(duì)象:

private? final Logger logger = LoggerFactory.getLogger(XXX.class);

不過(guò)為了簡(jiǎn)化,lombok給我們提供了注解進(jìn)行日志輸出楚堤。(需要idea有l(wèi)ombok的插件疫蔓,還有需要lombok的依賴(lài))

lombok支持
提供注解,直接使用log

下面我們?cè)賮?lái)簡(jiǎn)單談一下日志的profile功能身冬,要想支持profile功能也很簡(jiǎn)單衅胀,比如不要在叫l(wèi)ogback.xml,而是logback-spring.xml酥筝,這樣日志配置將由springboot來(lái)進(jìn)行處理滚躯,就可以使用到profile功能。

logback-spring.xml

最后嘿歌,我們?cè)僬f(shuō)一下掸掏,如果不想使用springboot默認(rèn)支持的slf4j+logback的方式,而是slf4j+xxx呢宙帝?

很簡(jiǎn)單阅束,根據(jù)上文理論,第一茄唐,排除依賴(lài)(logback)息裸;第二蝇更,加入依賴(lài)(log4j);第三呼盆,加入具體日志配置即可(log4j.xml)年扩。


結(jié)束語(yǔ)

好了,到這里访圃,我們就以SpringBoot為切入點(diǎn)厨幻,對(duì)整個(gè)Java平臺(tái)的日志進(jìn)行了一個(gè)分析,相信以后在開(kāi)發(fā)過(guò)程中遇到日志的有關(guān)問(wèn)題腿时,能夠心中有數(shù)~

create by zhangfengzhe

2018-08-18

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末况脆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子批糟,更是在濱河造成了極大的恐慌格了,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件徽鼎,死亡現(xiàn)場(chǎng)離奇詭異盛末,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)否淤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)悄但,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人石抡,你說(shuō)我怎么就攤上這事檐嚣。” “怎么了啰扛?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,461評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵嚎京,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我侠讯,道長(zhǎng),這世上最難降的妖魔是什么暑刃? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,135評(píng)論 1 300
  • 正文 為了忘掉前任厢漩,我火速辦了婚禮,結(jié)果婚禮上岩臣,老公的妹妹穿的比我還像新娘溜嗜。我一直安慰自己,他們只是感情好架谎,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布炸宵。 她就那樣靜靜地躺著,像睡著了一般谷扣。 火紅的嫁衣襯著肌膚如雪土全。 梳的紋絲不亂的頭發(fā)上捎琐,一...
    開(kāi)封第一講書(shū)人閱讀 52,736評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音裹匙,去河邊找鬼瑞凑。 笑死,一個(gè)胖子當(dāng)著我的面吹牛概页,可吹牛的內(nèi)容都是我干的籽御。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼惰匙,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼技掏!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起项鬼,我...
    開(kāi)封第一講書(shū)人閱讀 40,124評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤哑梳,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后秃臣,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體涧衙,經(jīng)...
    沈念sama閱讀 46,657評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評(píng)論 3 342
  • 正文 我和宋清朗相戀三年奥此,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了弧哎。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,872評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡稚虎,死狀恐怖撤嫩,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蠢终,我是刑警寧澤序攘,帶...
    沈念sama閱讀 36,533評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站寻拂,受9級(jí)特大地震影響程奠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜祭钉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評(píng)論 3 336
  • 文/蒙蒙 一瞄沙、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧慌核,春花似錦距境、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,700評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至粟按,卻和暖如春诬滩,著一層夾襖步出監(jiān)牢的瞬間霹粥,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,819評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工碱呼, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蒙挑,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,304評(píng)論 3 379
  • 正文 我出身青樓愚臀,卻偏偏與公主長(zhǎng)得像忆蚀,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子姑裂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評(píng)論 2 361

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

  • 歷史 log4j可以當(dāng)之無(wú)愧地說(shuō)是Java日志框架的元老馋袜,1999年發(fā)布首個(gè)版本,2012年發(fā)布最后一個(gè)版本舶斧,20...
    kelgon閱讀 10,165評(píng)論 3 53
  • 作為Java開(kāi)發(fā)人員欣鳖,對(duì)于日志記錄框架一定非常熟悉。而且?guī)缀踉谒袘?yīng)用里面茴厉,一定會(huì)用到各種各樣的日志框架用來(lái)記錄程...
    意識(shí)流丶閱讀 13,934評(píng)論 0 13
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,867評(píng)論 6 342
  • 文章作者:Tyan博客:noahsnail.com 2.Introduction to the Spring Fr...
    SnailTyan閱讀 5,392評(píng)論 7 56
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理泽台,服務(wù)發(fā)現(xiàn),斷路器矾缓,智...
    卡卡羅2017閱讀 134,716評(píng)論 18 139