Golang學(xué)習(xí)筆記-zerolog

zerolog是一個(gè)高性能喧伞,支持日志等級(jí)窟她,鉤子的結(jié)構(gòu)化日志庫纸泡。log的Print()和Printf()方法默認(rèn)輸出到os.Stderr漂问,默認(rèn)日志等級(jí)為debug,用法和官方log庫相同女揭。

package main

import (
    "github.com/rs/zerolog"
    "github.com/rs/zerolog/log"
)


func main(){
    zerolog.TimeFieldFormat = zerolog.TimeFormatUnix
    log.Print("hello world")
}
{"level":"debug","time":1576398679,"message":"hello world"}

日志等級(jí)

zerolog有下面幾種日志等級(jí)蚤假,調(diào)用zerolog.SetGlobalLevel()設(shè)置日志等級(jí)。

  • panic (zerolog.PanicLevel, 5)
  • fatal (zerolog.FatalLevel, 4)
  • error (zerolog.ErrorLevel, 3)
  • warn (zerolog.WarnLevel, 2)
  • info (zerolog.InfoLevel, 1)
  • debug (zerolog.DebugLevel, 0)
  • trace (zerolog.TraceLevel, -1)

添加數(shù)據(jù)到上下文

zerolog可以將數(shù)據(jù)以key-value對(duì)的形式添加到一條日志事件的上下文中吧兔,重復(fù)的key-value對(duì)不會(huì)刪除磷仰。調(diào)用Msg方法輸出日志,也可以調(diào)用Send方法輸出日志境蔼,其本質(zhì)是調(diào)用Msg("")灶平。

package main

import (
    "github.com/rs/zerolog/log"
)


func main(){
    log.Debug().
        Str("name", "xy").
        Str("name", "xy").
        Float64("height", 100.0).
        Msg("create object")
}

{"level":"debug","name":"xy","name":"xy","height":100,"time":"2019-12-15T17:17:46+08:00","message":"create object"}

自定義字段名

package main

import (
    "github.com/rs/zerolog"
    "github.com/rs/zerolog/log"
)


func main(){
    zerolog.TimestampFieldName = "t"
    zerolog.LevelFieldName = "l"
    zerolog.MessageFieldName = "m"
    log.Debug().
        Str("name", "xy").
        Float64("height", 100.0).
        Msg("create object")
}
{"l":"debug","name":"xy","height":100,"t":"2019-12-15T17:04:24+08:00","m":"create object"}

添加文件名和代碼行

package main

import (
    "github.com/rs/zerolog/log"
)


func main(){
    log.Logger = log.With().Caller().Logger()
    log.Info().Msg("hello world")
}

{"level":"info","time":"2019-12-15T17:13:02+08:00","caller":"C:/Users/Administrator/go/src/studygo/main.go:10","message":"hello world"}

logger

zerolog可以創(chuàng)建不同的logger實(shí)例來輸出日志伺通,下面代碼創(chuàng)建了一個(gè)新的logger替換了log的logger,其中zerolog.ConsoleWriter可以使輸出的日志更加友好民逼,日志等級(jí)變?yōu)椴噬摹?/p>

package main

import (
    "github.com/rs/zerolog"
    "github.com/rs/zerolog/log"
    "os"
)


func main(){
    log.Logger = log.Output(zerolog.ConsoleWriter{Out: os.Stderr,TimeFormat: "2006-01-02 15:04:05.000"})
    log.Info().Msg("hello world")
}

鉤子

利用鉤子可以攔截日志事件,從而實(shí)現(xiàn)各種擴(kuò)展功能涮帘,例如將日志輸出到文件拼苍。

package main

import (
    "fmt"
    "github.com/rs/zerolog"
    "github.com/rs/zerolog/log"
)

type LogHook struct{}

func (hook LogHook) Run(e *zerolog.Event, level zerolog.Level, msg string) {
    fmt.Println(msg)
}

func main(){
    log.Logger=log.Hook(LogHook{})
    log.Info().Msg("hello world")
}

hello world
{"level":"info","time":"2019-12-15T17:28:58+08:00","message":"hello world"}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市调缨,隨后出現(xiàn)的幾起案子疮鲫,更是在濱河造成了極大的恐慌,老刑警劉巖弦叶,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件俊犯,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡伤哺,警方通過查閱死者的電腦和手機(jī)燕侠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來立莉,“玉大人绢彤,你說我怎么就攤上這事◎殉埽” “怎么了茫舶?”我有些...
    開封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)刹淌。 經(jīng)常有香客問我饶氏,道長(zhǎng),這世上最難降的妖魔是什么有勾? 我笑而不...
    開封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任疹启,我火速辦了婚禮,結(jié)果婚禮上蔼卡,老公的妹妹穿的比我還像新娘皮仁。我一直安慰自己,他們只是感情好菲宴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開白布贷祈。 她就那樣靜靜地躺著,像睡著了一般喝峦。 火紅的嫁衣襯著肌膚如雪势誊。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天谣蠢,我揣著相機(jī)與錄音粟耻,去河邊找鬼查近。 笑死,一個(gè)胖子當(dāng)著我的面吹牛挤忙,可吹牛的內(nèi)容都是我干的霜威。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼册烈,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼戈泼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起赏僧,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤大猛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后淀零,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挽绩,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年驾中,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了唉堪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡肩民,死狀恐怖巨坊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情此改,我是刑警寧澤趾撵,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站共啃,受9級(jí)特大地震影響占调,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜移剪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一究珊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧纵苛,春花似錦剿涮、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至怀吻,卻和暖如春瞬浓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蓬坡。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工猿棉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留磅叛,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓萨赁,卻偏偏與公主長(zhǎng)得像弊琴,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子杖爽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

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

  • 寫在前面的話 代碼中的# > 表示的是輸出結(jié)果 輸入 使用input()函數(shù) 用法 注意input函數(shù)輸出的均是字...
    FlyingLittlePG閱讀 2,764評(píng)論 0 8
  • 一:根節(jié)點(diǎn)包含的屬性: scan: 當(dāng)此屬性設(shè)置為true時(shí)敲董,配置文件如果發(fā)生改變,將會(huì)被重新加載掂林,默認(rèn)值為tru...
    把愛放下會(huì)走更遠(yuǎn)閱讀 632評(píng)論 0 0
  • (一)臣缀、日志相關(guān)概念 1坝橡、日志的作用 通過log的分析泻帮,可以方便用戶了解系統(tǒng)或軟件、應(yīng)用的運(yùn)行情況计寇;如果你的應(yīng)用l...
    Rainy丶Wang閱讀 606評(píng)論 0 0
  • 一锣杂、logback的介紹Logback是由log4j創(chuàng)始人設(shè)計(jì)的另一個(gè)開源日志組件,官方網(wǎng)站: http://lo...
    Running小琦閱讀 782評(píng)論 0 8
  • Log Java日志:(slf4j、log4j番宁、logback元莫、common-logging ) slf4j 是規(guī)...
    年少懵懂丶流年夢(mèng)閱讀 17,555評(píng)論 1 11