Zap logger 将 UUID 添加到 golang 中的所有日志中

2024年 2月 14日 41.8k 0

zap logger 将 uuid 添加到 golang 中的所有日志中

php小编西瓜介绍:在golang中,日志记录是开发过程中不可或缺的一部分。而Zap logger则是一个非常流行的日志记录库,它提供了丰富的功能和高性能。最近,有一个新的功能被添加到了Zap logger中,即将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 作为参数传递给所有方法,以将其打印在日志信息或错误中。

解决方法

您将不得不稍微重新安排您的代码,因为您只是在处理程序中创建 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"}

登录后复制

以上就是Zap logger 将 UUID 添加到 golang 中的所有日志中的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论