一、介紹
在許多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è)置日志記錄器的代碼如下:
下面的示例中,我們將建立一個到URL的HTTP連接姑曙,并將狀態(tài)代碼/錯誤記錄到日志文件中襟交。
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 Logger和Logger。
在性能很好但不是很關(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界面引润。