Zap 记录器将 UUID 添加到 golang 中的所有日志

我在 lambda 中使用了这个方法:


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))

}

我有一个问题,是否可以将 UUID 添加到所有日志而不是一个一个地添加?,因为在我需要打印的每个日志中,我需要添加zap.Any("uuid", uuid)


问题是我需要将 UUID 作为参数传递给所有方法以在日志信息或错误中打印它。


慕码人2483693
浏览 100回答 1
1回答

红糖糍粑

你将不得不稍微重新安排你的代码,因为你只是在处理程序中创建 UUID,这意味着它是特定于请求的,而记录器是全局的......但是要点,特定于库,是你必须创建一个子记录器(事实上,你已经在做:你只需要在那里传递字段)。任何后续写入子记录器的日志都将包含这些字段。例如: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"}
打开App,查看更多内容
随时随地看视频慕课网APP