說說Java日志

前言

我們在編寫代碼時,都知道在關(guān)鍵算法侧甫,邏輯性較強的地方添加注釋珊佣。一來提高了代碼的可維護性。二來讓代碼有了自可讀性披粟。如果我們把注釋理解為靜態(tài)的自可讀性咒锻。那么,程序在運行時僻爽,我們?nèi)绾尾拍苤莱绦虻膶嶋H運行路徑呢虫碉?這就是今天的主角--日志!

為什么要打日志?

有很多朋友胸梆,不太喜歡打日志敦捧。好幾百,甚至上千行的代碼碰镜。啪兢卵,啪,啪的全寫完绪颖!自信滿滿秽荤,一行日志也沒打。聯(lián)調(diào)柠横,測試窃款,上線都沒問題。系統(tǒng)運行一段時間后牍氛,莫名的出現(xiàn)問題晨继。那么,到底是哪個地方出現(xiàn)問題了搬俊?方法的入?yún)⑹鞘裁次裳铮肯到y(tǒng)走到哪一步了?一無所知唉擂。這下就只剩抓瞎了餐屎。從這里我們應(yīng)該可以看出,打日志是非常有必要的玩祟。我們梳理一下腹缩,打日志有諸多好處。

最直接的好處就是方便解決BUG了。

記錄請求的耗時時間藏鹊,特別是接入第三方供應(yīng)商時胜臊,調(diào)用遠程服務(wù)時,我們可以通過日志來記錄請求的耗時時間伙判。

對關(guān)鍵業(yè)務(wù),關(guān)鍵算法的入?yún)⒑诔溃约敖Y(jié)果打點并記錄下來宴抚。

最后: 記錄日志是給自己分析問題,解決bug用的甫煞。我們盡量記錄的盡可能簡潔菇曲,易懂以及清晰,理想情況下甚至能通過日志還原一次請求抚吠,一次調(diào)用的全過程常潮。

如何打日志?

上面我們說了為什么需要打日志。現(xiàn)在我們說說楷力,如何打日志喊式。以我們最常用slf4j這個日志組件來說,它對應(yīng)的日志級別有: trace, debug萧朝,info岔留,warn,error這五個日志級別检柬。其范圍依次為: error>warn>info>debug>trace献联。

我們在日常開發(fā)中:

在開發(fā)初期,我們可以在進入方法時用info模式的日志級別何址,記錄方法的入里逆,出參。在遠程方法調(diào)用前用爪,調(diào)用后原押,使用info級別。記錄遠程方法的耗時项钮。在try{}catch處班眯,使用error級別日志級別,記錄信息烁巫。以方便用來快速查找署隘,以及分析問題。

服務(wù)運行穩(wěn)定一段時間后亚隙,我們可以將必須記錄的參數(shù)磁餐,修改為warn級別。日志級別設(shè)置為warn。也就是說诊霹,只顯示warn和error級別中的日志羞延。(有很多公司,都以error級別的日志作為報警信息脾还,發(fā)送給對應(yīng)的應(yīng)用負責(zé)人伴箩。)

在生產(chǎn)環(huán)境中,禁止啟用debug級別的日志鄙漏。因為debug級別的日志會顯示很多沒必要的日志嗤谚。這樣很容易造成服務(wù)器資源浪費。嚴重時甚至造成服務(wù)器撐滿怔蚌。直接導(dǎo)致服務(wù)不可用巩步。

凡事都是物極必反。同樣的桦踊,日志也不是越多越好椅野,過多的打印日志,同樣的也會造成服務(wù)性能下降籍胯。甚至造成服務(wù)器壓力過大竟闪。直接影響服務(wù)的可用性。

我們可以通過如下形式來記錄日志:

以log4j+slf4j-api為例:

pom.xml依賴:

<dependency>

? <groupId>org.slf4j</groupId>

? <artifactId>slf4j-api</artifactId>

? <version>1.7.25</version>

</dependency>

<dependency>

? <groupId>org.slf4j</groupId>

? <artifactId>slf4j-log4j12</artifactId>

? <version>1.7.25</version>

? <scope>test</scope>

</dependency>

<dependency>

? <groupId>log4j</groupId>

? <artifactId>log4j</artifactId>

? <version>1.2.17</version>

</dependency>

以下打日志例子:

import org.junit.Test;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

public class LogTest {

? ? private static Logger logger = LoggerFactory.getLogger(LogTest.class);

? ? @Test

? public void testLog(){

? ? ? ? String name="andyqian";

? ? ? ? String blog = "www.andyqian.com";

? ? ? ? //就日志

? ? ? ? logger.debug("name: {} and blog : {} ", name, blog);

? ? }

}

我們通過占位符的形式芒炼,記錄日志瘫怜。不建議使用字符串拼接的形式來記錄日志。

常用Java日志框架

在Java中本刽,常見的日志框架有

JDK自帶的JDK Logger鲸湃。

Apche commons Logging。

Apache log4j子寓。

Slf4j ( Simple Logging Facade for Java)

Logback

Apache log4j 2 (這其實是Apache log4j的升級版本暗挑。在log4j的基礎(chǔ)上,性能有進一步的提高斜友。)

在日常的開發(fā)中炸裆,我們通常都是通過Slf4j+的實現(xiàn)。以上述案例中鲜屏,我們就說到了(slf4j+log4j的形式)烹看。在實際使用中,我們也可以通過slf4j+ logback日志的形式做為日志組合洛史。

ps:各個日志框架的性能不在本文討論之中惯殊。有興趣的朋友,可自行測試也殖。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末土思,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌己儒,老刑警劉巖崎岂,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異闪湾,居然都是意外死亡冲甘,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門途样,熙熙樓的掌柜王于貴愁眉苦臉地迎上來损合,“玉大人,你說我怎么就攤上這事娘纷。” “怎么了跋炕?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵赖晶,是天一觀的道長。 經(jīng)常有香客問我辐烂,道長遏插,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任纠修,我火速辦了婚禮胳嘲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘扣草。我一直安慰自己了牛,他們只是感情好,可當我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布辰妙。 她就那樣靜靜地躺著鹰祸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪密浑。 梳的紋絲不亂的頭發(fā)上蛙婴,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天,我揣著相機與錄音尔破,去河邊找鬼街图。 笑死,一個胖子當著我的面吹牛懒构,可吹牛的內(nèi)容都是我干的餐济。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼痴脾,長吁一口氣:“原來是場噩夢啊……” “哼颤介!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤滚朵,失蹤者是張志新(化名)和其女友劉穎冤灾,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體辕近,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡韵吨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了移宅。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片归粉。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖漏峰,靈堂內(nèi)的尸體忽然破棺而出糠悼,到底是詐尸還是另有隱情,我是刑警寧澤浅乔,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布倔喂,位于F島的核電站,受9級特大地震影響靖苇,放射性物質(zhì)發(fā)生泄漏席噩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一贤壁、第九天 我趴在偏房一處隱蔽的房頂上張望悼枢。 院中可真熱鬧,春花似錦脾拆、人聲如沸馒索。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽双揪。三九已至,卻和暖如春包帚,著一層夾襖步出監(jiān)牢的瞬間渔期,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工渴邦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留疯趟,地道東北人。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓谋梭,卻偏偏與公主長得像信峻,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子瓮床,可洞房花燭夜當晚...
    茶點故事閱讀 44,927評論 2 355

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