成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > golang有用的庫及工具 之 zap.Logger包的使用指南

golang有用的庫及工具 之 zap.Logger包的使用指南

熱門標(biāo)簽:官渡電銷外呼管理系統(tǒng)怎么收費 地圖區(qū)域圖標(biāo)注后導(dǎo)出 貴州電話智能外呼系統(tǒng) 杭州人工智能電銷機器人費用 江蘇呼叫中心外呼系統(tǒng)有效果嗎 利用地圖標(biāo)注位置 赤峰電銷 谷歌美發(fā)店地圖標(biāo)注 400開頭電話怎樣申請

zap.Logger 是go語言中相對日志庫中性能最高的。那么如何開始使用?

不多說直接上代碼:

import (
  "encoding/json"
  "fmt"
  "log"
  "go.uber.org/zap"
  "go.uber.org/zap/zapcore"
)
var Logger *zap.Logger
func InitLogger() {
  // 日志地址 "out.log" 自定義
  lp := Conf.Common.LogPath
  // 日志級別 DEBUG,ERROR, INFO
  lv := Conf.Common.LogLevel
  // 是否 DEBUG
  isDebug := true
  if Conf.Common.IsDebug != true {
   isDebug = false
  }
  initLogger(lp, lv, isDebug)
  log.SetFlags(log.Lmicroseconds | log.Lshortfile | log.LstdFlags)
}
func initLogger(lp string, lv string, isDebug bool) {
  var js string
  if isDebug {
   js = fmt.Sprintf(`{
   "level": "%s",
   "encoding": "json",
   "outputPaths": ["stdout"],
   "errorOutputPaths": ["stdout"]
   }`, lv)
  } else {
   js = fmt.Sprintf(`{
   "level": "%s",
   "encoding": "json",
   "outputPaths": ["%s"],
   "errorOutputPaths": ["%s"]
   }`, lv, lp, lp)
  }
  var cfg zap.Config
  if err := json.Unmarshal([]byte(js), cfg); err != nil {
   panic(err)
  }
  cfg.EncoderConfig = zap.NewProductionEncoderConfig()
  cfg.EncoderConfig.EncodeTime = zapcore.ISO8601TimeEncoder
  var err error
  Logger, err = cfg.Build()
  if err != nil {
   log.Fatal("init logger error: ", err)
  }
}

如何使用:

func TestInitLogger(t *testing.T) {
  InitLogger("out.log", "DEBUG", false)
  s := []string{
   "hello info",
   "hello error",
   "hello debug",
   "hello fatal",
  }
  Log.Info("info:", zap.String("s", s[0]))
  Log.Error("info:", zap.String("s", s[1]))
  Log.Debug("info:", zap.String("s", s[2]))
  Log.Fatal("info:", zap.String("s", s[3]))
}

輸出:

{"level":"info","ts":"2017-10-25 13:45:42.332","caller":"logger/logger_test.go:16","msg":"info:","s":"hello info"}
{"level":"error","ts":"2017-10-25 13:45:42.396","caller":"logger/logger_test.go:17","msg":"info:","s":"hello error","stacktrace":"go.uber.org/zap.Stack\n\tD:/gopath/src/go.uber.org/zap/field.go:191\ngo.uber.org/zap.(*Logger).check\n\tD:/gopath/src/go.uber.org/zap/logger.go:301\ngo.uber.org/zap.(*Logger).Error\n\tD:/gopath/src/go.uber.org/zap/logger.go:202\ngithub.com/corego/hermes/logger.TestInitLogger\n\tD:/gopath/src/github.com/corego/hermes/logger/logger_test.go:17\ntesting.tRunner\n\tD:/Program Files (x86)/go/src/testing/testing.go:746"}
{"level":"debug","ts":"2017-10-25 13:45:42.396","caller":"logger/logger_test.go:18","msg":"info:","s":"hello debug"}
{"level":"fatal","ts":"2017-10-25 13:45:42.396","caller":"logger/logger_test.go:19","msg":"info:","s":"hello fatal","stacktrace":"go.uber.org/zap.Stack\n\tD:/gopath/src/go.uber.org/zap/field.go:191\ngo.uber.org/zap.(*Logger).check\n\tD:/gopath/src/go.uber.org/zap/logger.go:301\ngo.uber.org/zap.(*Logger).Fatal\n\tD:/gopath/src/go.uber.org/zap/logger.go:235\ngithub.com/corego/hermes/logger.TestInitLogger\n\tD:/gopath/src/github.com/corego/hermes/logger/logger_test.go:19\ntesting.tRunner\n\tD:/Program Files (x86)/go/src/testing/testing.go:746"}

拓展:Golang成長之路:使用Zap來做日志服務(wù)

我們在項目中,經(jīng)常會記錄一些數(shù)據(jù)信息到文件中,或者日志文件。

例如nginx會有nginx訪問請求日志,使用golang的時候,我也想做一個這樣的訪問日志,所以我就找到了go的一個開源高效的日志庫zap。

很多人也使用logrus或者go自帶的Logger(支持的東西太少,性能一般),具體為啥最后選擇了zap,是因為很多人說zap性能更高些,當(dāng)然我自己沒有測試過。

1、安裝zap

go get -u go.uber.org/zap

如果沒反應(yīng),可能需要配置下代理,

go env -w GOPROXY=https://goproxy.cn

然后在執(zhí)行安裝的命令。

2、簡單實例(默認(rèn)配置)

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

package main 
import (
  "go.uber.org/zap"
  "time"
)
 
func main() {
  // zap.NewDevelopment 格式化輸出
  logger, _ := zap.NewDevelopment()
  defer logger.Sync()
  logger.Info("測試",
    zap.String("url", "http://www.baidu.com"),
    zap.Int("attempt", 3),
    zap.Duration("backoff", time.Second),
  )
 
  // zap.NewProduction json序列化輸出
  logger, _ := zap.NewProduction()
  defer logger.Sync()
  logger.Info("測試",
    zap.String("url", "http://www.baidu.com"),
    zap.Int("attempt", 3),
    zap.Duration("backoff", time.Second),
  )
}

3、自定義配置

封裝好一個logger包

package logger 
import (
  "go.uber.org/zap"
  "go.uber.org/zap/zapcore"
  "time"
  "fmt"
)
 
var sugarLogger *zap.SugaredLogger
 
//格式化日期
func formatEncodeTime(t time.Time, enc zapcore.PrimitiveArrayEncoder) {
 enc.AppendString(fmt.Sprintf("%d-%02d-%02d %02d:%02d:%02d", t.Year(), t.Month(), t.Day(), t.Hour(), t.Minute(), t.Second()))
}
 
func InitConfig() *zap.SugaredLogger {
  encoderConfig := zapcore.EncoderConfig{
    TimeKey:    "ts",
    LevelKey:    "level",
    NameKey:    "logger",
    CallerKey:   "caller",
    MessageKey:   "msg",
    StacktraceKey: "stacktrace",
    LineEnding:   zapcore.DefaultLineEnding,
    EncodeLevel:  zapcore.LowercaseLevelEncoder, // 小寫編碼器
    EncodeTime:   formatEncodeTime,    //時間格式
    EncodeDuration: zapcore.SecondsDurationEncoder,
    EncodeCaller:  zapcore.FullCallerEncoder,   // 全路徑編碼器
  }
 
  // 設(shè)置日志級別(默認(rèn)info級別,可以根據(jù)需要設(shè)置級別)
  atom := zap.NewAtomicLevelAt(zap.InfoLevel)
 
  config := zap.Config{
    Level:      atom,                        // 日志級別
    Development:   true,                        // 開發(fā)模式,堆棧跟蹤
    Encoding:     "json",                       // 輸出格式 console 或 json
    EncoderConfig:  encoderConfig,                    // 編碼器配置
    OutputPaths:   []string{"stdout", '需要寫入文件的路徑'},       // 日志寫入文件的地址
    ErrorOutputPaths: []string{"stderr", '需要寫入文件的路徑'},   // 將系統(tǒng)內(nèi)的error記錄到文件的地址
  }
 
  // 構(gòu)建日志
  logger, _ := config.Build()
  sugarLogger = logger.Sugar()
  return sugarLogger 
}
 
func Debug(args ...interface{}) {
 sugarLogger.Debug(args...)
}
 
func Debugf(template string, args ...interface{}) {
 sugarLogger.Debugf(template, args...)
}
 
func Info(args ...interface{}) {
 sugarLogger.Info(args...)
}
 
func Infof(template string, args ...interface{}) {
 sugarLogger.Infof(template, args...)
}
 
func Infow(template string, args ...interface{}) {
 sugarLogger.Infow(template, args...)
}
 
func Warn(args ...interface{}) {
 sugarLogger.Warn(args...)
}
 
func Warnf(template string, args ...interface{}) {
 sugarLogger.Warnf(template, args...)
}
 
func Error(args ...interface{}) {
 sugarLogger.Error(args...)
}
 
func Errorf(template string, args ...interface{}) {
 sugarLogger.Errorf(template, args...)
}
 
func DPanic(args ...interface{}) {
 sugarLogger.DPanic(args...)
}
 
func DPanicf(template string, args ...interface{}) {
 sugarLogger.DPanicf(template, args...)
}
 
func Panic(args ...interface{}) {
 sugarLogger.Panic(args...)
}
 
func Panicf(template string, args ...interface{}) {
 sugarLogger.Panicf(template, args...)
}
 
func Fatal(args ...interface{}) {
 sugarLogger.Fatal(args...)
}
 
func Fatalf(template string, args ...interface{}) {
 sugarLogger.Fatalf(template, args...)
}

EncoderConfig配置說明

MessageKey:輸入信息的key名

LevelKey:輸出日志級別的key名

TimeKey:輸出時間的key名

NameKey CallerKey StacktraceKey跟以上類似,看名字就知道

LineEnding:每行的分隔符。基本zapcore.DefaultLineEnding 即"\n"

EncodeLevel:基本zapcore.LowercaseLevelEncoder。將日志級別字符串轉(zhuǎn)化為小寫

EncodeTime:輸出的時間格式

EncodeDuration:一般zapcore.SecondsDurationEncoder,執(zhí)行消耗的時間轉(zhuǎn)化成浮點型的秒

EncodeCaller:一般zapcore.ShortCallerEncoder,以包/文件:行號 格式化調(diào)用堆棧

EncodeName:可選值。

使用案例

package main 
import (
 "logger"http://導(dǎo)入寫好的包(具體需要改為自己寫的路徑)
)
 
func main() {
 //初始化日志配置
 logger.InitConfig()
 
 //寫入文件
 logger.Infow("access_log",
 "code", 200,
 "ip", 192.168.1.1,
 "Method", "POST",
 "url", "www.baidu.com",
 "latencyTime(ms)", 1000,
 )
}

好了,這就是自己搗鼓的zap使用方法,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Golang logrus 日志包及日志切割的實現(xiàn)
  • golang elasticsearch Client的使用詳解
  • Golang的func參數(shù)及返回值操作
  • golang協(xié)程池模擬實現(xiàn)群發(fā)郵件功能
  • golang 比較浮點數(shù)的大小方式
  • 解決Golang中g(shù)oroutine執(zhí)行速度的問題
  • 解決golang結(jié)構(gòu)體tag編譯錯誤的問題
  • golang日志包logger的用法詳解

標(biāo)簽:泰安 武漢 松原 保定 黔西 宜春 鷹潭 河池

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang有用的庫及工具 之 zap.Logger包的使用指南》,本文關(guān)鍵詞  golang,有,用的,庫,及,工具,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang有用的庫及工具 之 zap.Logger包的使用指南》相關(guān)的同類信息!
  • 本頁收集關(guān)于golang有用的庫及工具 之 zap.Logger包的使用指南的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    中文日本在线观看| 亚欧洲精品在线视频免费观看| 久久久久久高清| 亚洲成人av在线电影| 91夜夜蜜桃臀一区二区三区| 日韩av男人天堂| 男女裸体影院高潮| 九色porny蝌蚪视频在线观看| 国产 欧美 日韩 在线| 精品欧美色视频网站在线观看| 91香蕉视频污| av伊人久久| 亚洲精品美女| 91在线视频观看免费| 中文在线√天堂| 日韩精品中文字幕视频在线| 毛片精品免费在线观看| 日韩欧美国产小视频| 国产黄色免费网站| 国产蜜臀av在线播放| wwwwxxxx日韩| 成人免费一区二区三区牛牛| aa成人免费视频| 亚洲色图一区二区| 国产精品500部| 亚洲二区在线观看| www.四虎在线观看| 911国产在线| 中文字幕欧美在线观看| 天天操天天摸天天舔| 日韩精品在线视频免费观看| 可以在线看的黄色网址| 国产欧美精品一二三| 久久久久99精品成人片试看| 人人精品视频| 91麻豆福利精品推荐| 欧美一区二区激情| 免费av片在线观看一道本| 欧美xxxx黑人又粗又长精品| 国产传媒一区二区三区| 日韩福利二区| 成年永久一区二区三区免费视频| 黄色精品视频在线观看| 中文字幕一区二区三区在线乱码| 日本视频免费在线| jizzjizz日本护士视频| 久久中文字幕人妻| 欧美videosex性极品hd| 国产美女精品写真福利视频| 久久新电视剧免费观看| 亚洲欧洲午夜一线一品| 亚洲精品成人悠悠色影视| 色综合久久六月婷婷中文字幕| 亚洲国产视频一区二区三区| 91麻豆精品秘密| 少妇特黄a一区二区三区| 91美女免费看| 熟女少妇内射日韩亚洲| 久久久久精彩视频| 国产乱码精品一区二区三区亚洲人| 亚洲一区二区三区日本久久九| 高清成人免费视频| 久久99精品久久久久久琪琪| 中文在线观看免费网站| 色8久久精品久久久久久蜜| 亚洲欧洲国产专区| 麻豆精品91| 刘亦菲国产毛片bd| 欧美情侣在线播放| 久久精品免费播放| 精品视频在线观看一区| 中文字幕亚洲一区二区三区| 欧美一区二区视频在线观看2022| 在线观看免费电影| 欧美性色aⅴ视频一区日韩精品| 青青草原av在线| 国产91丝袜在线播放九色| 国产精品99久久久久久www| 欧美黑人xxxx| 午夜久久久久久噜噜噜噜| 久久99精品久久久久久欧洲站| 国产超级av在线| 亚洲国产精品久久久久婷婷软件| 26uuu亚洲| 国产欧美精品一区二区色综合朱莉| 日韩 欧美 高清| 国产桃色电影在线播放| 久久综合社区| 亚洲黄色av一区| av在线之家电影网站| 亚洲国产欧美在线观看| 国模少妇一区二区三区| 手机福利小视频在线播放| 国产女主播福利| 精品亚洲国产成人av制服丝袜| 国内精品第一页| 国产91久久精品一区二区| 国产性猛交96| 日韩欧美电影在线| 亚欧洲精品在线视频| 国产精一品亚洲二区在线视频| 亚洲免费三区一区二区| 伊人色综合一区二区三区影院视频| 超级碰碰视频| 一女被多男玩喷潮视频| 精品无码一区二区三区爱欲| 国产综合网站| 欧美日韩一区三区四区| 97超级碰碰碰| 蜜桃av成人| 波多野结衣在线观看一区二区三区| 日本免费在线一区| 日韩二区三区在线观看| 最新av中文字幕| 香蕉97视频观看在线观看| 色妞www精品视频| 国产精品亚发布| 国产日韩成人精品| 成人免费在线电影| 2023国产精品久久久精品双| 91精品国产色综合久久| 一区二区三区精品久久久| 国产精品毛片无码| sdde在线播放一区二区| 午夜免费啪视频观看视频| 中文字幕av一区二区三区人| 2023国产精品自拍| 视频一区二区三区中文字幕| 欧美aa免费在线| 日本精品免费一区二区三区| 国产v片免费观看| 在线观看操人| 激情小说网站亚洲综合网| 国内av一区二区| 国产一区二区在线视频你懂的| 91久久国产精品| 麻豆传媒网站在线观看| 精品亚洲免a| 天天综合中文字幕| 先锋影音在av资源看片| 久久久久亚洲AV成人网人人小说| 欧美va视频| 香蕉网在线播放| 色中色综合影院手机版在线观看| 九九热精彩视频| 欧美风情在线观看| 自拍偷拍18p| 亚洲精品手机在线| 天使萌一区二区三区免费观看| 嘿咻视频在线看| 日韩av一卡二卡| 亚洲欧美日本日韩| 欧美三级电影精品| 青青草视频在线免费直播| 6080成人| 91亚洲国产成人久久精品麻豆| 色视频在线观看免费| 日韩影院免费视频| 男女羞羞视频教学| 色午夜这里只有精品| 日本中文字幕伦在线观看| 亚洲精品美女久久7777777| 韩国福利在线| sm久久捆绑调教精品一区| 91免费欧美精品| 亚洲天堂精品在线| 日本公妇乱淫免费视频一区三区| 亚洲破处大片| 最新国产成人在线观看| 91在线看国产| 久草视频在线播放| 国产欧美日韩成人| 亚洲欧美另类图片| 性欧美lx╳lx╳| 精品动漫一区二区三区在线观看| 一区二区三区无毛| 国产乱子轮精品视频| 色黄网站在线观看| www.色婷婷| 日本久久久久久久久久久久| 日韩手机在线观看| 国产日产亚洲精品系列| 国产超碰97| 亚洲国内高清视频| 天天色天天上天天操| 中文字幕99页| 蜜桃传媒在线观看免费进入| 中文字幕国产综合| www.日本高清| 亚洲三区在线观看无套内射| 伊人五月天婷婷| 综合av色偷偷网| 神马午夜一区二区| 最新福利小视频在线播放| 欧美一级淫片丝袜脚交| 亚洲第一页在线观看| 91国产精品成人| 天堂电影院在线| 蜜桃传媒麻豆第一区在线观看| 亚洲综合欧美综合| 你懂的网站在线播放| 乳奴隷乳フ辱julia在线观看| 国产日韩av在线播放| 色姑娘资源站| 亚洲一二三区视频| a级国产乱理论片在线观看99| 黄色一区二区在线| 国产在线拍揄自揄拍| 黄色av网站在线| 最新中文字幕av| 国产成人亚洲综合a∨婷婷| 亚洲在线视频免费观看| 欧洲亚洲精品在线| 99re免费99re在线视频手机版| 可以免费看黄色的网站| 污视频软件在线观看| gay欧美网站| 欧美色视频一区二区三区在线观看| 小香蕉视频在线| 亚洲欧美韩国| av五月天在线| 外国成人激情视频| 亚洲激情网站免费观看| 欧美性爽视频| 伊人色综合久久天天人手人婷| а√最新版地址在线天堂| 成人黄色国产精品网站大全在线免费观看| 日韩第一页在线观看| 国产成人禁片免费观看视频| 草逼视频免费看| 国产91免费看| 国产一区二区三区久久| 日韩精品视频网站| 无码h肉动漫在线观看| 在线视频一区二区三区四区| 久热在线视频精品网站| 国产成人激情小视频| 无码人妻久久一区二区三区蜜桃| 美女黄色一级视频| 超碰资源在线| 欧美日韩xx| 午夜免费日韩视频| 丝袜足控免费网站xx网站| 三级av在线| 天堂在线观看视频观看www| 国产精品白浆视频免费观看| 亚洲国产精品成人综合色在线婷婷| 国产无套精品一区二区| 国产精品久久久久久亚洲影视| 精品av一区二区| 久草免费福利视频| 灌醉mj刚成年的大学平面模特| 日韩欧美三级在线| 男人艹女人在线观看| 成人不卡免费av| 欧美成人一二三区| 精品国产精品国产精品| 亚洲女同精品视频| 黄页网址在线观看| 欧美午夜性囗交xxxx| 日本道中文字幕| 欧美特大特白屁股xxxx| 国产精品精华液网站| 亚洲国产私拍精品国模在线观看| 小说区图片区色综合区| 亚洲综合欧美色图| 宅男噜噜噜66国产精品免费| 天天操夜夜操av| 寂寞少妇一区二区三区| 18禁网站免费无遮挡无码中文| 九色视频成人自拍| c#hpsocket| 欧美日韩一二三四五区| 成人看片爽爽爽| 国内精品伊人久久久久av影院| 亚洲国产日韩一区无码精品久久久| 青青草在线视频免费观看| 日韩中文字幕在线视频观看| 亚洲高清色图| 成人18精品视频| 日韩av一卡二卡三卡| 国产精品免费av一区二区| 在线观看av网站永久| 国产在线青青草| 高清日韩av电影| 国产精品高精视频免费| 国产精品免费一区二区三区都可以| 久久精品国产成人| 一区二区三区四区视频在线| 丰满少妇乱子伦精品看片| 美女网站一区二区| 午夜精品福利电影| 成人永久在线| 日本wwwwwww| 欧美一级在线视频| 欧美日韩久久| 中文字幕免费在线观看视频| 亚洲一级特黄| 91色综合久久久久婷婷| 久久久久99人妻一区二区三区| 亚洲另类在线观看| 国模一区二区三区私拍视频| 欧美日韩电影免费看| 视频区 图片区 小说区| 亚洲欧美精品中文第三| 先锋影音欧美| 欧美成人黄色网址| 欧美裸身视频免费观看| 国产精品久久久久久久久久精爆| 黄色网址视频在线观看| 成人一区在线看| 久久97精品久久久久久久不卡| 欧美综合在线观看视频| 国产高清视频在线播放| 亚洲成av人片一区二区| 欧美特级黄色录像| 日韩久久电影| 免费特级黄毛片| 亚洲国产精品视频在线观看| eeuss第一页| 白浆爆出在线观看| 欧美一区二区三区久久精品| 国产精品视频yy9099| 国产另类ts人妖一区二区| 久久久久成人精品无码中文字幕| 91性高湖久久久久久久久_久久99| 免费高清在线视频一区·| 亚洲精品videossex少妇|