golang中常見的logrus日志庫
戰(zhàn)術(shù)臥倒
golang中常見的日志包是logrus, 根據(jù)logrus的胚子和我們的生產(chǎn)要求,給出一個生產(chǎn)可用的logrus實(shí)踐姿勢。
主謂賓定狀補(bǔ)
logrus是一個結(jié)構(gòu)化的、可插拔的、兼容golang標(biāo)準(zhǔn)log api的日志庫。
快速過一下能力
- 支持對output=TTY增加關(guān)鍵字顏色
- 內(nèi)置JSONFormatter和TextFormatter(默認(rèn))兩種Formatter
- 支持輸出logger所在的函數(shù)行位置
log.SetReportCaller(true) - 可以兼容golang內(nèi)置的標(biāo)準(zhǔn)log庫, 建議無腦替換
- 鼓勵輸出可解析的日志字段,而不是大段的無法結(jié)構(gòu)化的文本日志
log.WithFields(log.Fields{
"event": event,
"topic": topic,
"key": key,
}).Fatal("Failed to send event")基于現(xiàn)狀,湊了6個錢包上生產(chǎn),下面給出一些自己的生產(chǎn)實(shí)踐。
添磚加瓦
1. logrus不支持滾動日志
好馬配好鞍 https://github.com/lestrrat-go/file-rotatelogs 讓你下雨天不再哭泣。
它會根據(jù)配置自動按照時間切分日志,并滾動清理日志(不用配磁盤報(bào)警,不用擔(dān)心磁盤滿故障)。
logf, err := rotatelogs.New(
cfg.Log.LogDir+logName+".%Y%m%d%H%M",
rotatelogs.WithLinkName(cfg.Log.LogDir+logName),
rotatelogs.WithMaxAge(24*time.Hour),
rotatelogs.WithRotationTime(time.Hour),
)
if err != nil {
stdLog.Printf("failed to create rotatelogs: %s", err)
return
}2. 日志格式化
java生態(tài)默認(rèn)日志輸出格式:
11:44:44.827 WARN [93ef3E0120160803114444] [main] [ClassPathXmlApplicationContext] Exception encountered during context initialization - cancelling refresh attempt
在公司中javaer占據(jù)主流,故java的默認(rèn)格式就成了公司集中式日志的"標(biāo)準(zhǔn)"格式。
很明顯,logrus默認(rèn)的兩種Formatter都不匹配。
github.com/antonfisher/nested-logrus-formatter 讓你柳暗花明。
log.SetFormatter(&nested.Formatter{ // 嵌套日志兼容skynet日志格式
HideKeys: true,
FieldsOrder: []string{"region", "node", "topic"},
TimestampFormat: "2006-01-02 15:04:05.000", // 顯示ms
})3. 自定義Hook用法:輸出默認(rèn)字段
寫本文的時候,發(fā)現(xiàn)logrus官方本身支持輸出默認(rèn)日志字段。
requestLogger := log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip}) requestLogger.Warn("something not great happened")
Hook: 通常 鉤子函數(shù)用于在觸發(fā)某種事件時附帶一些動作。
logrus的Hook定義:logEntry滿足指定的logLevel日志時, 你想要做的動作(你甚至可以不設(shè)置output直接在hook輸出日志, 這就是內(nèi)置write hook的實(shí)現(xiàn))。
type Hook interface {
Levels() []Level
Fire(*Entry) error
}示例代碼為logLevel>=info的logEntry,固定了2個日志字段。
type FixedFieldHook struct {
LogLevels []logrus.Level
FixedField map[string]string
}
// Fire will be called when some logging function is called with current hook
// It will format log entry to string and write it to appropriate writer
func (hook *FixedFieldHook) Fire(entry *logrus.Entry) error {
for k, v := range hook.FixedField {
entry.Data[k] = v
}
return nil
}
log.AddHook(&FixedFieldHook{ // Set fixed field
FixedField: map[string]string{"region": cfg.LocalRegion, "node": ip},
LogLevels: []logrus.Level{
logrus.InfoLevel,
logrus.ErrorLevel,
logrus.WarnLevel,
logrus.FatalLevel,
},
})
拋磚引玉,戰(zhàn)術(shù)臥倒。
到此這篇關(guān)于golang中常見的logrus日志庫的文章就介紹到這了,更多相關(guān)golang中l(wèi)ogrus日志庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
本地使用Docker搭建go開發(fā)環(huán)境的全過程
最近想學(xué)習(xí)一下golang,自己之前一直把環(huán)境全部安裝在docker上,所以這次也想把golang的環(huán)境安裝在docker上,下面這篇文章主要給大家介紹了關(guān)于本地使用Docker搭建go開發(fā)環(huán)境的相關(guān)資料,需要的朋友可以參考下2022-07-07
Golang教程之不可重入函數(shù)的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于Golang教程之不可重入函數(shù)的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09
使用systemd部署和守護(hù)golang應(yīng)用程序的操作方法
systemd是一個流行的守護(hù)進(jìn)程管理器,可以輕松管理服務(wù)的啟動、停止、重啟等操作,讓我們的應(yīng)用程序始終保持在線,本文介紹了如何使用systemd部署和守護(hù)golang應(yīng)用程序,感興趣的朋友一起看看吧2023-10-10
Go語言實(shí)現(xiàn)一個Http?Server框架(一)?http庫的使用
本文主要介紹用Go語言實(shí)現(xiàn)一個Http?Server框架中對http庫的基本使用說明,文中有詳細(xì)的代碼示例,感興趣的同學(xué)可以借鑒一下2023-04-04

