go語言的Zap日志庫

一、介紹

在許多Go語言項(xiàng)目中彪置,我們需要一個好的日志記錄器能夠提供下面這些功能:

1拄踪、能夠?qū)⑹录涗浀轿募校皇菓?yīng)用程序控制臺拳魁。

2惶桐、日志切割-能夠根據(jù)文件大小、時間或間隔等來切割日志文件潘懊。

3姚糊、支持不同的日志級別。例如INFO授舟,DEBUG叛拷,ERROR等。

4岂却、能夠打印基本信息忿薇,如調(diào)用文件/函數(shù)名和行號,日志時間等躏哩。


二署浩、默認(rèn)的Go Logger

在介紹Uber-go的zap包之前,讓我們先來看看Go語言提供的基本日志功能扫尺。Go語言提供的默認(rèn)日志包是https://golang.org/pkg/log/筋栋。

1、實(shí)現(xiàn)Go Logger

實(shí)現(xiàn)一個Go語言中的日志記錄器非常簡單——創(chuàng)建一個新的日志文件正驻,然后設(shè)置它為日志的輸出位置弊攘。

設(shè)置日志記錄器的代碼如下:

設(shè)置日志記錄器

下面的示例中,我們將建立一個到URL的HTTP連接姑曙,并將狀態(tài)代碼/錯誤記錄到日志文件中襟交。

示例

main函數(shù)中有:

main函數(shù)

輸出如下:

輸出


2、Go Logger的優(yōu)勢和劣勢

(1)優(yōu)勢

它最大的優(yōu)點(diǎn)是使用非常簡單伤靠。我們可以設(shè)置任何io.Writer作為日志記錄輸出并向其發(fā)送要寫入的日志捣域。

(2)劣勢

①僅限基本的日志級別

只有一個Print選項(xiàng),不支持INFO/DEBUG等多個級別。

②對于錯誤日志焕梅,它有Fatal和Panic

Fatal日志通過調(diào)用os.Exit(1)來結(jié)束程序迹鹅;

Panic日志在寫入日志消息之后拋出一個panic;

但是它缺少一個ERROR日志級別贞言,這個級別可以在不拋出panic或退出程序的情況下記錄錯誤斜棚;

③缺乏日志格式化的能力

例如記錄調(diào)用者的函數(shù)名和行號,格式化日期和時間格式该窗。等等弟蚀。

④不提供日志切割的能力


三、Uber-go Zap

Zap是非撑膊叮快的粗梭、結(jié)構(gòu)化的,分日志級別的Go日志庫级零。

1断医、為什么選擇Uber-go Zap

主要因?yàn)樗瑫r提供了結(jié)構(gòu)化日志記錄printf風(fēng)格的日志記錄,而且速度非常的快奏纪。

根據(jù)Uber-go Zap的文檔鉴嗤,它的性能比類似的結(jié)構(gòu)化日志包更好——也比標(biāo)準(zhǔn)庫更快。 以下是Zap發(fā)布的基準(zhǔn)測試信息

記錄一條消息和10個字段:

性能提升表

2序调、安裝

go get -u go.uber.org/zap


3醉锅、配置和使用

Zap提供了兩種類型的日志記錄器—Sugared LoggerLogger

在性能很好但不是很關(guān)鍵的上下文中发绢,使用SugaredLogger硬耍。它比其他結(jié)構(gòu)化日志記錄包快4-10倍,并且支持結(jié)構(gòu)化和printf風(fēng)格的日志記錄边酒。

在每一微秒和每一次內(nèi)存分配都很重要的上下文中经柴,使用Logger。它甚至比SugaredLogger更快墩朦,內(nèi)存分配次數(shù)也更少坯认,但它只支持強(qiáng)類型的結(jié)構(gòu)化日志記錄。

(1)Logger

通過調(diào)用zap.NewProduction()/zap.NewDevelopment()或者zap.Example()創(chuàng)建一個Logger氓涣。在通過Logger來調(diào)用info牛哺、error等方法。

默認(rèn)情況下劳吠,日志都會打印到應(yīng)用程序的console界面引润。


(2)定制Logger

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市赴背,隨后出現(xiàn)的幾起案子椰拒,更是在濱河造成了極大的恐慌晶渠,老刑警劉巖凰荚,帶你破解...
    沈念sama閱讀 221,548評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件燃观,死亡現(xiàn)場離奇詭異,居然都是意外死亡便瑟,警方通過查閱死者的電腦和手機(jī)缆毁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來到涂,“玉大人脊框,你說我怎么就攤上這事〖模” “怎么了浇雹?”我有些...
    開封第一講書人閱讀 167,990評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長屿讽。 經(jīng)常有香客問我昭灵,道長,這世上最難降的妖魔是什么伐谈? 我笑而不...
    開封第一講書人閱讀 59,618評論 1 296
  • 正文 為了忘掉前任烂完,我火速辦了婚禮,結(jié)果婚禮上诵棵,老公的妹妹穿的比我還像新娘抠蚣。我一直安慰自己,他們只是感情好履澳,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評論 6 397
  • 文/花漫 我一把揭開白布嘶窄。 她就那樣靜靜地躺著,像睡著了一般距贷。 火紅的嫁衣襯著肌膚如雪柄冲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,246評論 1 308
  • 那天储耐,我揣著相機(jī)與錄音羊初,去河邊找鬼。 笑死什湘,一個胖子當(dāng)著我的面吹牛长赞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播闽撤,決...
    沈念sama閱讀 40,819評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼得哆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了哟旗?” 一聲冷哼從身側(cè)響起贩据,我...
    開封第一講書人閱讀 39,725評論 0 276
  • 序言:老撾萬榮一對情侶失蹤栋操,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后饱亮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體矾芙,經(jīng)...
    沈念sama閱讀 46,268評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評論 3 340
  • 正文 我和宋清朗相戀三年近上,在試婚紗的時候發(fā)現(xiàn)自己被綠了剔宪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,488評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡壹无,死狀恐怖葱绒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情斗锭,我是刑警寧澤地淀,帶...
    沈念sama閱讀 36,181評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站岖是,受9級特大地震影響帮毁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜璧微,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評論 3 333
  • 文/蒙蒙 一作箍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧前硫,春花似錦胞得、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至危号,卻和暖如春牧愁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背外莲。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評論 1 272
  • 我被黑心中介騙來泰國打工猪半, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人偷线。 一個月前我還...
    沈念sama閱讀 48,897評論 3 376
  • 正文 我出身青樓磨确,卻偏偏與公主長得像,于是被迫代替她去往敵國和親声邦。 傳聞我的和親對象是個殘疾皇子乏奥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評論 2 359

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