第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Zap 記錄器將 UUID 添加到 golang 中的所有日志

Zap 記錄器將 UUID 添加到 golang 中的所有日志

Go
慕碼人2483693 2023-03-21 10:05:57
我在 lambda 中使用了這個(gè)方法:import (    "os"    "go.uber.org/zap"    "go.uber.org/zap/zapcore")func InitLogger() *zap.Logger {    config := zap.NewProductionEncoderConfig()    config.EncodeTime = zapcore.RFC3339TimeEncoder    consoleEncoder := zapcore.NewJSONEncoder(config)    core := zapcore.NewTee(zapcore.NewCore(consoleEncoder, zapcore.AddSync(os.Stdout), zapcore.InfoLevel))    return zap.New(core).With()}在我的 lambda 處理程序中,我有:var (    log *zap.Logger)func init() {    log = u.InitLogger()}func handler(r events.APIGatewayProxyRequest) (*events.APIGatewayProxyResponse, error) {    out, err := exec.Command("uuidgen").Output()    uuid := strings.ReplaceAll(string(out), "\n", "")    if err != nil {        log.Error(err.Error())    }    log.Info("PRINT_1", zap.Any("uuid", uuid), zap.Any("Request", r.Body))}我有一個(gè)問題,是否可以將 UUID 添加到所有日志而不是一個(gè)一個(gè)地添加?,因?yàn)樵谖倚枰蛴〉拿總€(gè)日志中,我需要添加zap.Any("uuid", uuid)問題是我需要將 UUID 作為參數(shù)傳遞給所有方法以在日志信息或錯(cuò)誤中打印它。
查看完整描述

1 回答

?
紅糖糍粑

TA貢獻(xiàn)1815條經(jīng)驗(yàn) 獲得超6個(gè)贊

你將不得不稍微重新安排你的代碼,因?yàn)槟阒皇窃谔幚沓绦蛑袆?chuàng)建 UUID,這意味著它是特定于請(qǐng)求的,而記錄器是全局的......


但是要點(diǎn),特定于庫,是你必須創(chuàng)建一個(gè)子記錄器(事實(shí)上,你已經(jīng)在做:你只需要在那里傳遞字段)。任何后續(xù)寫入子記錄器的日志都將包含這些字段。


例如:


func main() {

    logger := InitLogger(zap.String("foo", "bar"))

    logger.Info("First message with our `foo` key")

    logger.Info("Second message with our `foo` key")

}


func InitLogger(fields ...zap.Field) *zap.Logger {

    config := zap.NewProductionEncoderConfig()

    config.EncodeTime = zapcore.RFC3339TimeEncoder

    consoleEncoder := zapcore.NewJSONEncoder(config)

    core := zapcore.NewTee(zapcore.NewCore(consoleEncoder, zapcore.AddSync(os.Stdout), zapcore.InfoLevel))

    return zap.New(core).With(fields...)

}

輸出:


{"level":"info","ts":"2022-11-24T18:30:45+01:00","msg":"First message with our `foo` key","foo":"bar"}

{"level":"info","ts":"2022-11-24T18:30:45+01:00","msg":"Second message with our `foo` key","foo":"bar"}



查看完整回答
反對(duì) 回復(fù) 2023-03-21
  • 1 回答
  • 0 關(guān)注
  • 161 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)